GAMES101 闫令琪图形学 作业1

作业1

问题描述
在这里插入图片描述
问题分析:

第一个函数:
get_model_matrix(float rotation_angle):
逐个元素地构建模型变换矩阵并返回该矩阵。在此函数中,你只需要实现三维中绕 z 轴旋转的变换矩阵,而不用处理平移与缩放。

绕 z 轴旋转的变换矩阵:
在这里插入图片描述

    double r = rotation_angle / 180.0 * acos(-1);
    rotate << cos(r), -1.0f*sin(r), 0, 0,
              sin(r), cos(r), 0, 0,
              0, 0, 1, 0,
              0, 0, 0, 1;
    model = rotate * model;

第二个函数:
get_projection_matrix(float eye_fov, float aspect_ratio, float,zNear, float zFar): 使用给定的参数逐个元素地构建透视投影矩阵并返回该矩阵。

分析函数传递的四个参数:
在这里插入图片描述
FOV 视锥体竖直方向张开的角度
Aspect 当前摄像机的横纵比
Near 近处距离
Far 远处距离

透视投影的投影矩阵:
在这里插入图片描述

    float fov = fov / 180.0 * acos(-1);
    float cot = cos(fov / 2) / sin(fov / 2);
    frustum <<   cot/aspect, 0, 0, 0,
                 0, cot, 0, 0,
                 0, 0, -(Far+Near)/(Far-Near), -2*(Near*Far)/(Far-Near),
                 0, 0, -1, 0;
    projection = frustum * projection;
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值