当前位置: 首页 > news >正文

专业类网站线下推广的方式有哪些

专业类网站,线下推广的方式有哪些,网站建设综合,上海工商局企业信息查询法线贴图 法线贴图分两种#xff0c;一种是模型空间中的#xff0c;一种是切线空间中的 模型空间中的法线贴图的rgb代表着每个渲染像素法线的xyz#xff0c;与顶点坐标处于一个空间#xff0c;图片是五颜六色的。 切线空间中的法线贴图的rgb同样对应xyz#xff0c;是切线…法线贴图 法线贴图分两种一种是模型空间中的一种是切线空间中的 模型空间中的法线贴图的rgb代表着每个渲染像素法线的xyz与顶点坐标处于一个空间图片是五颜六色的。 切线空间中的法线贴图的rgb同样对应xyz是切线空间里的坐标切线空间里的z轴正向垂直与当前三角形便宜x是当前三角形片元表面的一个切线y是他们的叉积。 切线空间每个轴范围是-1到1.但图片本身0-255对应的是0-1.而多数法线都是都是(0,0,1)(即当前像素的法向量刚好就是当前片元的顶点法向量)转换到颜色空间就是(0.5,0.5,1)(法向量坐标可能为负但颜色范围始终为正)。因此图片主要是蓝紫色 两个完全一样材质的物体由于位置不同光照也会不同。如果用模型空间存储的法线贴图是绝对法线法向量会完全不同无法使用同一张物体。而切线空间存储的法线贴图完全是基于物体自身的是相对法线多个物体可以复用(优点)。但再实际计算时需要根据物体本身的缩放位移做相应的矩阵转换处理(缺点) 模型空间的法线贴图直接提取向量信息做为法线向量即可 Vec3f Model::getNormal(float x, float y) {TGAColor n normalTex_.get(x * normalTex_.get_width(), y * normalTex_.get_height());Vec3f res;for (int i 0; i 3; i) {res[i] n.bgra[i] / 255.f * 2 - 1.f;}return res; } //.... struct normalTexShader :public IShader {mat2, 3, float uv;virtual Vec4f vertex(int iface, int vertIdx, Matrix mvp) {Vec3f v model-vert(model-face(iface)[vertIdx]);uv.set_col(vertIdx, model-tverts(model-tface(iface)[vertIdx]));return mvp * embed4(v);}virtual bool fragment(Vec3f barycentricCoordinates, TGAColor color) {Vec2f texcoords uv * barycentricCoordinates;Vec3f normal model-getNormal(texcoords.x, texcoords.y);float I std::max(0.f, normal * light_dir);color model-getDiffuseColor(texcoords.x, texcoords.y) * I;return false;} };切线空间的法线贴图使用重点求出tbn矩阵将切线空间的法线转化到世界空间中 tbn矩阵 tbn矩阵 tbn矩阵 当tbn矩阵的n是模型空间时法线贴图取值经过tbn变换后是模型空间法线 当tbn矩阵的n是世界空间时法线贴图取值经过tbn变换后是世界空间法线 对于三角形表面所有点t切线和b切线都是相同的 顶点法线与面法线可能不同 面法线只是垂直于面的一条向量规定了面的正反而顶点法线才是用于光照信息的处理建模软件中顶点法线的最初是的默认情况也并非是面法线的平均只有当在建模软件中对物体进行了平滑着色后才会根据面法线平均得到顶点法线 因此要通过每个顶点的切线找到曲面的法线 struct Shader :public IShader {mat2, 3, float uv;Vec3f vp[3];Matrix MVP rasterizer-getProjection() * rasterizer-getModelView();mat3, 3, float n;virtual Vec4f vertex(int iface, int vertIdx) {Vec3f v model-vert(model-face(iface)[vertIdx]);uv.set_col(vertIdx, model-tverts(model-tface(iface)[vertIdx]));vp[vertIdx] v;n.set_col(vertIdx, model-nverts(model-nface(iface)[vertIdx]));return MVP * embed4(v);}virtual bool fragment(Vec3f barycentricCoordinates, TGAColor color) {Vec3f N (n * barycentricCoordinates).normalize();float u1 uv[0][1] - uv[0][0];float v1 uv[1][1] - uv[1][0];float u2 uv[0][2] - uv[0][0];float v2 uv[1][2] - uv[1][0];Vec3f e1 vp[1] - vp[0];Vec3f e2 vp[2] - vp[0];float f 1.f / (u1 * v2 - u2 * v1);Vec3f T (e1 * v2 - e2 * v1) * f;T T - N * (T * N);T.normalize();Vec3f B cross(N, T).normalize();mat3, 3, float TBN;TBN.set_col(0, T);TBN.set_col(1, B);TBN.set_col(2, N);Vec2f texcoords uv * barycentricCoordinates;Vec3f normal TBN * model-getNormal(texcoords.x, texcoords.y);float I std::max(0.f, normal * light_dir);color model-getDiffuseColor(texcoords.x, texcoords.y) * I;return false;} };有一点注意的是很多文章里的tbn矩阵只到了这步推导公式 求出了t和b向量后实际上还要加上N做一次正交化否则是不保证相互垂直的。最终才是tbn矩阵 项目跟随练习代码地址
http://www.w-s-a.com/news/74636/

相关文章:

  • 网站建设企业官网体验版是什么Wordpress哪个模板最快
  • 美丽说网站模板湖北可以做网站方案的公司
  • 北京西站进站最新规定建设网站的提成是多少
  • wordpress站点如何加速网站建设描述怎么写
  • 如何免费建造网站免费vi模板网站
  • 商丘做网站多少钱扬州大发网站建设
  • 网站建设哪家性价比高自己做项目的网站
  • 成立一个网站济宁营销型网站建设
  • 南通购物网站建设设计类平台网站
  • 专业网站建设咨询thinkphp网站源码下载
  • 怎么制作一个国外网站网站推广找哪家公司好
  • 免费做网站怎么做网站想在网上卖东西怎么注册
  • 淘宝网站建设的策划书网投怎么做网站
  • 如何免费做公司网站视频网站开发视频
  • 网站后台是怎么更新wordpress 大于2m的xm
  • 制作网页设计软件列表案例营销网站优化seo
  • 住房和建设建设局网站报告长官夫人在捉鬼
  • 用asp做网站需要什么软件天津建设工程信息网怎么注册
  • 一站式服务图片北京网站优化多少钱
  • 专业的论坛网站建设全网加速器
  • 成都品牌建设网站公司表单制作小程序
  • 手机端 网站 模板网页广告关不掉怎么办
  • 软装公司网站建设有没有做任务的网站
  • 加盟招商网站建设工业设计网站 知乎
  • 怎么做淘宝客网站优化免费windows7云主机
  • 有什么网站可以推广信息沈阳网站建设思路
  • 网站建设可研域名解析在线工具
  • 鲜花销售网站模板wordpress+模版+推荐
  • 企业网站报价网站域名 没有续费
  • 机关门户网站建设管理情况邮箱登陆嵌入网站