• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            逛奔的蝸牛

            我不聰明,但我會很努力

               ::  :: 新隨筆 ::  ::  :: 管理 ::
            vec4 v, u; mat4 m; v * u component-wise v * m v is row vector m * v v is column vector m * m linear-algebraic matrix multiplication Inverse 求逆 Transpose 轉置 gl_ModelViewMatrixInverse; gl_ModelViewProjectionMatrixInverseTranspose gl_NormalMatrix is the transpose of the inverse of the gl_ModelViewMatrix. function prototype: vec4 fract(vec4 x); == x - floor(x); <- [0, 1) // fract 片斷 vec4 clamp(float x, float minVal, float maxVal); returns min(max(x, minVal), maxVal); vec4 mix(vec4 x, vec4 y, vec4 a); return x * (1.0 - a) + y * a; vec4 step(vec4 edge, vec4 x); returns 0 if x < edge, otherwise returns 1. vec4 smoothstep(vec4 edge0, vec4 edge1, vec4 x); returns if x <= edge0, returns 1 if x >= edge1, perform hermite interpolation between 0 and 1 when edge0 < x < edge1 0到1之間的Hermite插值算法 equal to t = clamp((x - edge0) / (edge1 - edge0), 0.0, 1.0); return t * t * (3 - 2 * t); vec3 cross(vec3 x, vec3 y); // 只有這種形式,即只有三個component的向量才行 dot(N, L); result[0] = x[1] * y[2] - x[2] * y[1]; result[1] = x[2] * y[0] - x[0] * y[2]; result[2] = x[0] * y[1] - x[1] * y[0]; float dot(vec4 x, vec4 y); result = x[0] * y[0] + x[1] * y[1] + ...; vec4 reflect(vec4 I, vec4 N); // 反射光線向量 For the incident vector I and surface orientation N, returns the reflection direction result = I - 2.0 * dot(N, I) * N; vec3 ecPosition = vec3 (gl_ModelViewMatrix * gl_Vertex); vec3 tnorm = normalize(gl_NormalMatrix * gl_Normal); vec3 lightVec = normalize(LightPosition - ecPosition); vec3 reflectVec = reflect(-lightVec, tnorm); vec3 viewVec = normalize(-ecPosition); vec4 refract(vec4 I, vec4 N, float eta); // 折射光線向量 For the incident vector I and surface normal N and the ratio(比率) of refraction eta, returns the refraction vector. The returned result is computed as k = 1.0 - eta * eta * (1.0 - dot(N, I) * dot(N, I)); if (k < 0.0) { result = 0.0; // the return type is float of vec2/3/4 } else { result = eta * I - (eta * dot(N, I) *sqrt(k)) * N; } mat4 matrixComMult(mat4 x, mat4 y); component-wise to get linear-algebraic multiplication, use the multiply operator (*) mat4 x, y; x * y;
            posted on 2010-12-17 17:23 逛奔的蝸牛 閱讀(1493) 評論(0)  編輯 收藏 引用 所屬分類: OpenGL
            狠狠色丁香久久综合婷婷| 色综合久久久久综合体桃花网| 国产精品一区二区久久| 999久久久国产精品| 中文国产成人精品久久亚洲精品AⅤ无码精品 | 精品一久久香蕉国产线看播放 | 久久人妻少妇嫩草AV蜜桃| 久久亚洲欧美国产精品| 狠狠色综合网站久久久久久久| 久久AV无码精品人妻糸列| 久久久久成人精品无码| 精品久久久无码人妻中文字幕豆芽| 国产午夜精品久久久久九九电影| 久久精品无码专区免费东京热| 欧美激情精品久久久久久久九九九| 亚洲AV无码久久精品狠狠爱浪潮| 99久久精品国产综合一区| 国产三级久久久精品麻豆三级| 伊人久久大香线蕉综合热线| 四虎国产精品免费久久久| 国产成人久久AV免费| 亚洲精品无码成人片久久| 一本一道久久a久久精品综合 | 亚洲精品午夜国产va久久| 国产成人精品久久一区二区三区av | 国产午夜精品久久久久九九电影| 久久精品人人做人人妻人人玩| 久久亚洲AV无码精品色午夜| 四虎影视久久久免费| 欧美粉嫩小泬久久久久久久 | 波多野结衣久久一区二区| 久久成人国产精品一区二区| 2020久久精品国产免费| 日日噜噜夜夜狠狠久久丁香五月| 久久人人青草97香蕉| 狠狠色丁香婷婷久久综合五月| 色偷偷91久久综合噜噜噜噜| 久久久久亚洲AV无码观看| 97久久国产露脸精品国产| 99精品国产99久久久久久97| 久久亚洲熟女cc98cm|