1 / 62

음 영 (Shading)

음 영 (Shading). 음영의 개요. 음영이 없으면 3차원 물체도 2차원 이미지로 보일 수 있음 빛과 면사이의 상호 관계를 모델에 추가 광원 재질. 음영 (Shading). 조명과 재질 광원 Phong 반사 모형 벡터의 계산 다각형 음영 순환적 분할에 의한 구의 근사 OpenGL 의 광원 OpenGL 에서 재질의 지정 구 모델의 음영처리 전역적 렌더링. 조명과 재질. 조명과 반사를 물리적으로 완전히 모델링 하는 것은 불가능. 단순화.

eric-gould
Download Presentation

음 영 (Shading)

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. 음영 (Shading)

  2. 음영의 개요 • 음영이 없으면 3차원 물체도 2차원 이미지로 보일 수 있음 • 빛과 면사이의 상호 관계를 모델에 추가 • 광원 • 재질

  3. 음영 (Shading) • 조명과 재질 • 광원 • Phong 반사 모형 • 벡터의 계산 • 다각형 음영 • 순환적 분할에 의한 구의 근사 • OpenGL의 광원 • OpenGL에서 재질의 지정 • 구 모델의 음영처리 • 전역적 렌더링

  4. 조명과 재질 조명과 반사를 물리적으로 완전히 모델링 하는 것은 불가능 단순화 전역적 방법으로 근사(광선 추적, 방사성 기법) : 그래픽스 파이프라인에 부적합 단순화 국지적 조명 모델(Phong 반사모형 등) : 물리적 정확성과 계산효율의 절충 A와 B 사이에 무수한 반사작용이 발생

  5. 조명 모형 • 전역적 모형 • 광원과 표면 사이의 다중 상호 작용 고려 • 국지적 모형 • 광원과 표선사이의 단일 상호 작용만을 고려 • 표면상의 한 점은 다른 표면상의 점들에 독립적

  6. 빛과 표면 • 인간

  7. 빛, 표면과 컴퓨터 이미지 • 컴퓨터 많은 광선들은 투영면의 절단 사각형을 통과하지 않음 관측자를 투영면으로 대치

  8. 표면의 종류 전반사면 난반사면 반투명면

  9. 음영 (Shading) • 조명과 재질 • 광원 • Phong 반사 모형 • 벡터의 계산 • 다각형 음영 • 순환적 분할에 의한 구의 근사 • OpenGL의 광원 • OpenGL에서 재질의 지정 • 구 모델의 음영처리 • 전역적 렌더링

  10. 광원 (Light Sources) • 광원 : 위치 (x, y, z) , 방향 (,  ), 파장  • 조도함수 : I(x, y, z, , ,  )

  11.  I ( x, y, z, , ,  ) 광원에 의한 총 기여도 : 백열 전구 광원 계산이 어려움 : 단순화된 광원 모델이 필요

  12. 색 광원 • 광원은 주파수 의 연속함수이지만 단순한 R-G-B모형을 사용한다.

  13. 광원의 종류 • 주변광(Ambient Light) • 점광원(Point Light Source) • 집중광선(Spot Light) • 원거리 광원(Distant Light)

  14. 주변광 (Ambient Light) • 균일한 조명 • 실내의 객체들간의 다중 상호작용에 의해 형성된 조명을 모델 • 객체의 모든 점에서 동일한 세기의 빛을 받음

  15. 점광원 (Point Light Source) • 모든 방향으로 균일하게 빛을 방사 조도는 거리의 제곱에 반비례

  16. 암영부 반영부 점광원 (con’t) • 대비가 큰 이미지가 만들어진다 • 실제의 광원은 유한한 크기를 가지고 있으므로 좀더 부드러운 이미지가 만들어짐 • 주변광을 사용하여 높은 대비 효과를 완화시킬 수 있음 • 부드러운 조명을 위해 거리항을 수정

  17. Is f S 가 180이면 점광원이 됨 f e I  cos ( e 가 감쇄도를 제어) 집중광선 (Spot Light) • 작은 각도로만 빛을 방출 e : 집중광선 지수

  18. 집중광선 (con’t) • 두 단위 벡터가 주어졌을 경우 cos 값 계산

  19. 원거리 광원 • 점광원 • 표면상의 각 점으로부터 광원으로의 방향을 계산해야 함 (많은 시간 소요, 보다 좋은 화질) • 원거리 광원 • 방향을 한번만 계산(빠른 계산, 화질이 떨어짐) 광원의 위치 광원의 방향 각 점에 대한 방향 동일 점광원 원거리 광원

  20. 음영 (Shading) • 조명과 재질 • 광원 • Phong 반사 모형 • 벡터의 계산 • 다각형 음영 • 순환적 분할에 의한 구의 근사 • OpenGL의 광원 • OpenGL에서 재질의 지정 • 구 모델의 음영처리 • 전역적 렌더링

  21. 법선벡터 관측자 광원 완전 반사 방향 Phong모형에서 사용되는 벡터들 Phong 반사 모형 • 물리적 정확성과 계산효율의 절충 모형이다. • 그래픽스 파이프라인에 적합

  22. Phong 반사 모형 (con’t) • 세가지 광-재질 상호 작용 지원 • 주변반사 • 난반사 • 전반사 • 각 광원이 삼원색에 대하여 별도의 주변광 성분, 난반사광 성분, 전반사광 성분을 갖는다고 가정

  23. Phong 반사 모형 (con’t) • 점 P에서i 번째 광원의 조도 행렬 • 점 P에서의 반사항 행렬

  24. Phong 반사 모형 (con’t) • 광원 i 에 의한 P에서의 적색 세기 • 점 P에서 적색 세기 • 점 P의 색의 세기

  25. 주변반사 (Ambient Reflection) • 주변광의 세기 는 표면의 모든 점에서 같다 • 반사계수 • 0에서 1사이의 상수 • 표면의 재질에 따라 다름

  26. 난반사 (Diffuse Reflection) 정오에 더 밝음 일출과 일몰에 어두움 • 거친 표면 • 관측각도에 무관 반사되는 양은 광원의 방향에 의존적

  27. 난반사 (con’t) • 거리 d에의한 감쇄를 포함하면

  28. 전반사 (Specular Reflection) • 매끄러운 표면 • 반사가 일정 방향으로 됨 • 관측자의 위치에 따라 반사량이 다름 전반사의 입사각과 반사각이 같음

  29. : 광택 계수 전반사 (con’t)

  30. Phong 모형 Phong 모형에 의한 렌더링 - 재질 특성을 이용하여 각 찻잔이 다르게 보임

  31. 음영 (Shading) • 조명과 재질 • 광원 • Phong 반사 모형 • 벡터의 계산 • 다각형 음영 • 순환적 분할에 의한 구의 근사 • OpenGL의 광원 • OpenGL에서 재질의 지정 • 구 모델의 음영처리 • 전역적 렌더링

  32. 다각형 음영 • 세 가지 음영법 1) 평면 음영법 2) Gouraud 음영법 3) Phong 음영법 곡면을 다각형의 집합으로 렌더링 함으로써 속도 향상

  33. 평면 음영 (균일 음영) • 가정 • 원거리 관측자 • 원거리 광원 • n, l, v : 상수 각 다각형에 대해서 음영계산이 한번만 이루어짐

  34. 평면 음영 (con’t) • glShadeModel (GL_FLAT) 문제점 : 다각형 경계선이 뚜렷함

  35. Mach 띠

  36. glShadeModel(GL_FLAT) glShadeModel(GL_SMOOTH) Gouraud 음영 • 평면음영과 Gouraud 음영 • 한 다각형의 음영 계산에 인접한 다각형을 고려 • 다각형 내의 각 화소가 서로 다름 음영 값을 가짐

  37. Gouraud 음영의 원리 • 다각형 내의 각 화소에 대한 음영을 개별적으로 계산하는 것은 많은 시간이 소요됨 다각형의 정점에서만 음영 계산 • 다각형 내의 각 화소에 대해서 정점의 음영을 보간

  38. 각 정점에서 법선의 계산 • 각 정점에 대해서 • 인접한 다각형들의 법선을 평균 • 정점에서의 음영 계산

  39. n0 => c0 n1 => c1 n3 => c3 n2 => c2 보간 (Interpolation) • 정점들의 광도를 보간 N : 법선 벡터 C : 음영

  40. Phong 음영법 • 알고리즘 • 각 정점에 대해서 • 인접한 다각형들을 찾는다. • 다각형의 법선을 보간함으로써 정점에서의 법선을 계산 • 다각형 내의 각 화소에 대해서 • 법선을 보간 • 음영을 계산 • 더 많은 계산량, 하드웨어 구현이 더 어려움

  41. 법선의 보간

  42. 음영 (Shading) • 조명과 재질 • 광원 • Phong 반사 모형 • 벡터의 계산 • 다각형 음영 • 순환적 분할에 의한 구의 근사 • OpenGL의 광원 • OpenGL에서 재질의 지정 • 구 모델의 음영처리 • 전역적 렌더링

  43. OpenGL의 광원 • 8개 까지의 광원을 허용한다 • 각 광원별로 • 광원의 위치(점광원) 또는 방향(원거리광원) • 주변광, 난반사광, 전반사 광원의 세기 지정 glLightfv(source, parameter, pointer_to_array); glLightf(source, parameter, value);

  44. 광원 사용 방법 GLfloat light_0_pos[] = {1.0, 2.0, 3.0, 1.0}; GLfloat light_0_dir[] ={ 1.0, 2.0, 3.0, 0.0}; GLfloat diffuse_0[] = {1.0, 0.0, 0.0, 1.0}; GLfloat ambient_0[] ={ 1.0, 0.0, 0.0, 1.0}; GLfloat specular_0[] = {1.0, 1.0, 1.0, 1.0}; glEnable(GL_LIGHTING); glEnable(GL_LIGHT0); glLightfv(GL_LIGHT0, GL_POSITION, light_0_pos); glLightfv(GL_LIGHT0, GL_AMBIENT, ambient_0); glLightfv(GL_LIGHT0, GL_DIFFUSE, diffuse_0); glLightfv(GL_LIGHT0, GL_SPECULAR, specular_0); 광원 위치 광원방향 각 종류 별 세기 조명 활성화 첫번째 광원 활성화

  45. 의 상수값 설정 광원 사용 방법 (con’t) • 전역적 주변광 GLfloat global_ambient[] = {0.1, 0.1, 0.1, 1.0}; glLightModelfv(GL_LIGHT_MODEL_AMBIENT, global_ambient); glLightf(GL_LIGHT0, GL_CONSTANT_ATTENUATION, a); glLightf(GL_LIGHT0,GL_LINEAR_ATTENUATION, b); glLightf(GL_LIGHT0, GL_QUADRATIC_ATTENUATION, c);

  46. 광원 사용 방법 (con’t) • 관측자의 위치 glLightModeli(GL_LIGHT_MODEL_LOCAL_VIEWER, GL_TRUE); • 전면과 후면 모두 렌더링 glLightModel(GL_LIGHT_MODEL_TWO_SIDED, GL_TRUE); 전,후면 모두 렌더링

  47. glLightf(GL_LIGHT0, GL_SPOT_EXPONENT, int a) 광택계수 지정 • 전반사의 광택계수 지정 1 a  128 a = 2.0 a = 25.0

  48. 전반사의 범위 지정 glLightf(GL_LIGHT0, GL_SPOT_CUTOFF, float degree) 0 degree  90 degree = 10.0 degree = 30.0

  49. 음영 (Shading) • 조명과 재질 • 광원 • Phong 반사 모형 • 벡터의 계산 • 다각형 음영 • 순환적 분할에 의한 구의 근사 • OpenGL의 광원 • OpenGL에서 재질의 지정 • 구 모델의 음영처리 • 전역적 렌더링

  50. OpenGL에서 재질의 지정 • 재질 지정 함수 glMaterialfv(face, type, pointer_to_array); glMaterialf(face, value); 예) GLfloat ambient[] = {0.2, 0.2, 0.2, 1.0}; GLfloat diffuse[] = {1.0, 0.8, 0.0, 1.0}; GLfloat specular[] = {1.0, 1.0, 1.0, 1.0}; glMaterialfv(GL_FRONT_AND_BACK, GL_AMBIENT, ambient); glMaterialfv(GL_FRONT_AND_BACK, GL_DIFFUSE, diffuse); glMaterialfv(GL_FRONT_AND_BACK, GL_SPECULAR, specular);

More Related