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

哪些网站的活动策划做的好建设电商网站需要什么硬件

哪些网站的活动策划做的好,建设电商网站需要什么硬件,网上视频如何下载,网站建设介绍法线贴图 法线贴图分两种,一种是模型空间中的,一种是切线空间中的 模型空间中的法线贴图的rgb代表着每个渲染像素法线的xyz,与顶点坐标处于一个空间,图片是五颜六色的。 切线空间中的法线贴图的rgb同样对应xyz,是切线…

法线贴图
法线贴图分两种,一种是模型空间中的,一种是切线空间中的
在这里插入图片描述
模型空间中的法线贴图的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 {mat<2, 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 * embed<4>(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 {mat<2, 3, float> uv;Vec3f vp[3];Matrix MVP = rasterizer->getProjection() * rasterizer->getModelView();mat<3, 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 * embed<4>(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();mat<3, 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.yayakq.cn/news/349983/

相关文章:

  • 做外贸女装有哪些网站有哪些做各企业网站大概多少钱
  • 做网站快速排名广东惠州最新消息今天
  • 网站制作成品下载北京网站设计价格
  • 建设网站和推广中国化工网官网 网站建设
  • 中文网站建设模板下载哪个公司需要做网站
  • 后端网站开发遇到的难题解决2023免费推广网站
  • 企业网站icp南宁哪里有做网站的公司
  • h5手机模板网站网站内外链怎么做
  • 网站网页制作及优化电子商务的工作岗位有哪些?
  • 云互联的网站名字网站建设合作伙伴
  • 越秀网站建设策划网站信息内容建设局通报
  • 网站开发工作协议书范本aws的永久免费服务
  • 网站主关键词如何优化个人备案网站做电影站
  • 织梦做网站教程手机网站 源码
  • 完美代码网站口碑好的常州网站建设
  • 学做网站根学ps有前途吗私人浏览器
  • 查建设施工资质的网站网站建设经费的函
  • 网站站长需要具备什么素质电商网站建设与管理实践
  • 吉林省建设行业继续教续网站年轻人必备的十大网站
  • 电商购物网站开发阜宁企业做网站多少钱
  • 深圳建设合同备案 网站外贸做的社交网站有哪些
  • 衡水专业制作网站个人网站里在哪点击模版
  • 匿名网站建设网站建设分为哪些
  • 网站排版怎么做2345传奇世界游戏介绍
  • 网站打不开怎么解决备案网站负责人
  • 建设维护网站 未签订合同汕头网络推广电话
  • 广西新农村建设指导员网站专业做公司网页设计
  • 生态农业网站建设方案酷炫网站推荐
  • wordpress自适应建站建小网站多少钱
  • 山西做网站电商网站商品详情页