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

做系统哪个网站上的好考研培训机构排名前十

做系统哪个网站上的好,考研培训机构排名前十,如何开wordpress网站,做动画 的 网站有哪些软件文章目录 前言正文为什么需要屏幕空间变换?什么是屏幕空间变换?屏幕空间变换矩阵如何推导?问题描述步骤描述 结尾:喜欢的小伙伴点点关注赞哦! 前言 前面章节主要讲解了视图变换和投影变换,此时距离在屏幕空间显示也就…

文章目录

  • 前言
  • 正文
    • 为什么需要屏幕空间变换?
    • 什么是屏幕空间变换?
    • 屏幕空间变换矩阵如何推导?
      • 问题描述
      • 步骤描述
  • 结尾:喜欢的小伙伴点点关注+赞哦!

前言

前面章节主要讲解了视图变换和投影变换,此时距离在屏幕空间显示也就只差一步之遥了,只需要将NDC坐标转换为屏幕空间坐标即可!有了前面一些章节的学习,相信大家对于本章节的学习还是很容易的!

正文

为什么需要屏幕空间变换?

因为经过了视图变换和投影变换后,咱们已经将所有的顶点坐标转换成了NDC坐标,也就是x/y/z的范围都在 [ − 1 , 1 ] [-1,1] [1,1] 的坐标,但是正常咱们得电脑屏幕的XY坐标范围一般都是 [ 0 , w i d t h − 1 ] × [ 0 , h e i g h t − 1 ] [0,width-1] \times [0, height-1] [0,width1]×[0,height1] ,所以咱们需要屏幕空间变换!

什么是屏幕空间变换?

本质上和之前的视图变换、投影变换并无不同,就是一个矩阵罢了!

屏幕空间变换矩阵如何推导?

问题描述

将x坐标由 [ − 1 , 1 ] [-1,1] [1,1] 变换为 $ [0,screen_width - 1]$ ,将y坐标由 [ − 1 , 1 ] [-1,1] [1,1] 变换为 $ [0,screen_height - 1]$ ,将z坐标由 [ − 1 , 1 ] [-1,1] [1,1] 变换为 $ [0,1]$​.

如下图所示:

在这里插入图片描述

步骤描述

步骤1:将xyz坐标变换到 [ 0 , 1 ] [0,1] [0,1] 的范围

步骤2:将xy坐标缩放至 [ 0 , s c r e e n w i d t h − 1 ] × [ 0 , s c r e e n h e i g h t − 1 ] [0, screen_width - 1] \times [0, screen_height - 1] [0,screenwidth1]×[0,screenheight1]

咱们先思考下步骤1如何实现呢?当前的xyz坐标范围为 [ − 1 , 1 ] [-1,1] [1,1] ,目标的坐标范围为 [ 0 , 1 ] [0,1] [0,1] ,如何做呢?

这时候其实咱们分两步:

第一步:将 [ − 1 , 1 ] [-1,1] [1,1] 缩放至 [ − 0.5 , 0.5 ] [-0.5,0.5] [0.5,0.5] 的范围。

第二步:将 [ − 0.5 , 0.5 ] [-0.5,0.5] [0.5,0.5] 沿着对应轴轴方向移动0.5单位即可。

于是咱们分别得到缩放矩阵和平移矩阵如下:
S = [ 0.5 0 0 0 0 0.5 0 0 0 0 0.5 0 0 0 0 1 ] S = \begin{bmatrix} 0.5&0&0&0\\ 0&0.5&0&0\\ 0&0&0.5&0\\ 0&0&0&1\\ \end{bmatrix} S= 0.500000.500000.500001

T = [ 0 0 0 0.5 0 0 0 0.5 0 0 0 0.5 0 0 0 1 ] T = \begin{bmatrix} 0&0&0&0.5\\ 0&0&0&0.5\\ 0&0&0&0.5\\ 0&0&0&1\\ \end{bmatrix} T= 0000000000000.50.50.51

于是咱们只需要将两者相乘,即可获得相应的结果:
M 1 = T ∗ S = [ 0.5 0 0 0.5 0 0.5 0 0.5 0 0 0.5 0.5 0 0 0 1 ] M_1 = T * S = \begin{bmatrix} 0.5&0&0&0.5\\ 0&0.5&0&0.5\\ 0&0&0.5&0.5\\ 0&0&0&1\\ \end{bmatrix} M1=TS= 0.500000.500000.500.50.50.51

然后咱们思考下步骤二,当前的xy坐标范围为: [ 0 , 1 ] [0,1] [0,1] ,目标范围为 $[0,screen_width-1] 和 [0,screen_height-1] $

这个问题也就只是个xy轴的缩放问题而已,很容易得到以下缩放矩阵:
M 2 = [ s c r e e n _ w i d t h 0 0 0 0 s c r e e n _ h e i g h t 0 0 0 0 1 0 0 0 0 1 ] M_2 = \begin{bmatrix} screen\_width&0&0&0\\ 0&screen\_height&0&0\\ 0&0&1&0\\ 0&0&0&1\\ \end{bmatrix} M2= screen_width0000screen_height0000100001

然后咱们将步骤一的结果和步骤二的结果结合起来即可得到最终的屏幕空间变换矩阵,如下:
M s c r e e n = M 2 ∗ M 1 = M 2 = [ 0.5 ∗ s c r e e n _ w i d t h 0 0 0.5 ∗ s c r e e n _ w i d t h 0 0.5 ∗ s c r e e n _ h e i g h t 0 0.5 ∗ s c r e e n _ h e i g h t 0 0 0.5 0.5 0 0 0 1 ] M_{screen}= M_2 * M_1 = M_2 = \begin{bmatrix} 0.5*screen\_width&0&0&0.5*screen\_width\\ 0&0.5*screen\_height&0&0.5*screen\_height\\ 0&0&0.5&0.5\\ 0&0&0&1\\ \end{bmatrix} Mscreen=M2M1=M2= 0.5screen_width00000.5screen_height00000.500.5screen_width0.5screen_height0.51

于是大功告成啦!咱们成功的将NDC坐标转换成了屏幕空间坐标!

结尾:喜欢的小伙伴点点关注+赞哦!

你们的点赞就是我创作的最大动力!希望对各位小伙伴能够有所帮助哦,永远在学习的道路上伴你而行, 我是航火火,火一般的男人!

http://www.hkea.cn/news/702900/

相关文章:

  • 中国建设银行网站分期通百度推广登录平台网址
  • 公司内部网站源码新闻软文推广案例
  • vf建设银行网站谷歌seo排名
  • 如何申请商业服务器武汉seo工厂
  • 祥云平台英文网站微博指数查询入口
  • 公司网站建设准备资料今日重大财经新闻
  • 发布网站后备案免费网站建站页面
  • 浙江建设职业技术学院迎新网站做一个网站要多少钱
  • axure做网站好不好手机百度问一问
  • 开发微信小程序的流程广州seo优化电话
  • 小企业网站建设和管理全能搜
  • 无棣县建设局网站游戏优化大师下载安装
  • 小额贷款 网站模板品牌推广软文
  • 网站建设开发成本天津百度搜索网站排名
  • 做的好的营销型网站有哪些内容外贸网站外链平台
  • 东营网站建设预算价格百度网盘网页版入口官网
  • 网站建设中标公告18款禁用看奶app入口
  • 网站运营人员岗位职责长沙正规seo优化价格
  • cnzz统计代码放在后台网站为什么没显示seo的英文全称是什么
  • 杭州企业网站建设方案广告门
  • 自己免费做网站(二)seo优化公司信
  • 广州外贸b2b网站建设刷钻业务推广网站
  • 做企业网站用什么怎样宣传自己的品牌
  • 濮阳做网站的公司我的百度账号
  • 美食网站开发如何做好网络营销工作
  • 网站建设案例资料今天的新闻内容
  • 台州专业网站建设方案seo软文代写
  • 个人网站 百度推广全球搜索大全
  • 网站消息推送5118素材网站
  • 天津 响应式网站设计企业网站模板免费