【OpenGL实现04】glViewport - 玩家干预下改变视口和场景

一、说明

游戏开发中,人机互动机制是必不可少的。输入装置要么操作杆、要么是键盘。视口改变是无论在3D还是2D都要出现的功能,比如,google地图就是一个显然的变视口问题,视口如同一个放大镜在地图上方移动,理论上可以看到地图上所有地方。本篇就模拟实现之。

二、问题提出

我们从3D渲染初期,产生出很多疑问,比如说glViewport是个啥?如何看到该函数在工作。这里我们通过实验的手段,从键盘输入,使得视口不断平移,看到了glViewport的效果。

三、glViewport视觉函数

3.1 函数映射

  • glViewport — 设置视口
    glViewport ( GLint x, GLint y, GLsizei width, GLsizei height);

  • 参数
    x,y指定视口矩形的左下角, 以像素为单位。初始值为 (0,0)。

  • 描述
    glViewport指定x和y后,能够将设备坐标归一坐标,转化为窗口坐标。 假如 ( x n d , y n d ) (x_{nd},y_{nd}) (xnd,ynd)是规范化的设备坐标。 要想获取窗口坐标 ( x w , y w ) (x_w,y_w) (xw,yw)
    计算方法如下:
    x w = ( x n d + 1 ) ( w i d t h 2 ) + x x_w = (x_{nd}+1)(\frac{width}{2} ) +x xw=(xnd+1)(2width)+x
    y w = ( y n d + 1 ) ( h e i g h t 2 ) + y y_w = (y_{nd}+1)(\frac{height}{2} ) +y yw=(ynd+1)(2height)+y

这里x,y是glViewport 函数前两个参数。

void glDepthRange(	GLdouble nearVal,
 	GLdouble farVal);
 
void glDepthRangef(	GLfloat nearVal,
 	GLfloat farVal);

https://registry.khronos.org/OpenGL-Refpages/gl4/html/glDepthRange.xhtml

3.2 视口的范围查询语句

视口宽度和高度被限定实现的范围。 若要查询此范围,请使用参数 GL_MAX_VIEWPORT_DIMS调用glutGet.如:glutGet( GL_MAX_VIEWPORT_DIMS)

  • 错误
    GL_INVALID_VALUE如果 或 为负数,则生成。

  • 相关联的其它查询获取
    GL_VIEWPORT
    GL_MAX_VIEWPORT_DIMS

3.3 相配合的其它函数

视口变化后,需要立即调用显示函数实时地改变场景。因此,和两个场景显示函数有密切关系。

  • glutPostRedisplay()
  • glutDisplayFunc(Draw)

3.4 和相机函数的关系

视口函数和相机位置,都可以设定场景改变。但是有区别:

  • 视口坐标对景深无推进、拉远功能。相机位置可以。
  • 视口在透视平面上滑动,相机在三维世界坐标任意移动。
  • 视口和相机的位置都可以独立移动、相互无制约。
  • 在这里插入图片描述

以下相机设定,也有相关联,我们在后文中探讨。

glMatrixMode(GL_MODELVIEW);
glLoadIdentity();
gluLookAt(posX, posY, posZ, targetX, targetY, targetZ, 0, 1, 0); // eye(x,y,z), focal(x,y,z), up(x,y,z)

四、实现用键盘输入控制视口移动

4.1 实现键盘输入

键盘输入是GLUT库的相关函数,其使用方式范例代码如下:

from OpenGL.GL import *
from OpenGL.GLU import *
from OpenGL.GLUT import *
import sys
import math

px = 300; py = 300

def drawPlayer():
    glColor3f(1,1,0)
    glPointSize(18)
    glBegin(GL_POINTS)
    glVertex2i(px,py)
    glEnd()

def display():
    glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT)
    drawPlayer()
    glutSwapBuffers()

# Here is my keyboard input code
def buttons(key,x,y):
    print(key)
    global px, py
    if  key ==  b'a':    # GLUT_KEY_LEFT:
        px -= 5
    if key == b'd':
        px += 5
    if key ==  b'w':
        py -= 5
    if key ==  b's':
        py += 5
    glutPostRedisplay()

def init():
    glClearColor(0.3,0.3,0.3,0)
    gluOrtho2D(0,624,512,0)

def main():
    glutInit(sys.argv)
    glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGB)
    glutInitWindowSize(624, 512)
    window = glutCreateWindow("Raycaster in python")
    init()
    glutDisplayFunc(display)
    glutKeyboardFunc(buttons)
    glutSpecialFunc(buttons)
    glutMainLoop()

if __name__ == "__main__":
    main()

4.2 通过键盘输入移动视口

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/446302.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

实验二(二)OSPF路由协议基础实验

1.实验介绍 1.1关于本实验 开放式最短路径优先 OSPF(Open Shortest Path First)是IETF 组织开发的一个基于链路状态的内部网关协议(Interior Gateway Protocol)。目前针对 IPv4 协议使用的是 OSPF Version 2(RFC2328);OSPF 作为基于链路状态的协议,OSPF 具有以下优…

C语言程序与设计——函数(二)递归练习

在上一篇文章中接触到了递归这种编程方法,下面我们将用几个程序加深以下对递归的理解。 递归实际上就是程序调用自身的编程技巧 递归程序的组成: 边界条件处理针对于问题的处理过程和递归过程结果返回 二分查找 首先分析二分查找的查找逻辑: …

XXE漏洞基本原理(原理+靶场复现漏洞)

一、XXE漏洞与xml: 1、XXE漏洞的概念与基本原理: XXE漏洞,全称:"XML External Entity Injection"。 这种漏洞发生在应用程序解析XML输入数据时,如果没有禁止或限制对外部实体的引用和加载,那么…

【基于HTML5的网页设计及应用】——float实现页面布局

🎃个人专栏: 🐬 算法设计与分析:算法设计与分析_IT闫的博客-CSDN博客 🐳Java基础:Java基础_IT闫的博客-CSDN博客 🐋c语言:c语言_IT闫的博客-CSDN博客 🐟MySQL&#xff1a…

MySQL-----存储过程

▶ 介绍 存储过程是事先经过编译并存储在数据库中的一段SQL语句的集合,调用存储过程可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高数据处理的效率是有好处的。 存储过程思想上很简单,…

字典树、并查集

字典树 字典树( T r i e Trie Trie 树)是一种由 “节点” 和 “带有字符的边” 构成的树形结构。典型应用是用于统计和排序大量的字符串(但不仅限于字符串),经常被搜索引擎系统用于文本词频统计。优点:最大…

【三两波折】指向函数的指针

函数占用内存,在虚拟内存中属于txt段(只读),函数也是有地址的。 函数指针的定义: (返回值类型)(*函数指针名)(参数列表) 当我们调用Proc函数时,一般写作: double ans Proc(6, 7.8f); 实际上是C…

Intel® Extension for PyTorch*详细安装教程

最近在研究Intel的pytorch的加速拓展Intel Extension for PyTorch*,但是发现官网的文档全是英文的,不太好找安装教程。所以特此分享Intel Extension for PyTorch*的详细安装教程。 文章目录 一、安装所需系统要求1.1 硬件需求1.2 软件需求 二、准备2.1 安装驱动程序…

搭建nacos集群,并通过nginx实现负载均衡

nacos、eureka、consul、zookeeper等都是常用的微服务注册中心,这篇文章详细介绍一下在Ubuntu操作系统上搭建一个nacos的集群,以及通过nginx的反向代理功能实现nacos的负载均衡。 目录 一、安装nacos 1、安装nacos 2、修改nacos配置文件 3、创建naco…

【Hadoop大数据技术】——HDFS分布式文件系统(学习笔记)

📖 前言:Hadoop的核心是HDFS(Hadoop Distributed File System,Hadoop分布式文件系统)和MapReduce。其中,HDFS是解决海量大数据文件存储的问题,是目前应用最广泛的分布式文件系统。 目录 &#x…

智慧公厕_智慧化公厕_智慧的公厕_公厕智慧化_智能智慧公厕_智慧化的公厕

在当代城市发展中,智慧公厕作为公共厕所信息化的主要表现形式,正在以惊人的速度推动着城市公共环境卫生的智慧化进程。作为智慧城市体系的重要组成部分,智慧公厕不仅提供方便、卫生的公共厕所服务,还提升了城市整体形象&#xff0…

H5带建站时长可自定义背景官网/引导页源码

源码名称:带建站时长可自定义背景官网/引导页源码 源码介绍:一款带动态时间显示建站时长的引导页源码,可用于引导页、工作室官网、个人主页等。源码为H5自适应手机端、电脑端。 需求环境:H5 下载地址: https://www.…

java学习(集合)

一.集合(主要是单列集合和双列集合) 1.集合的框架体系(两大类) 2.collection接口是实现类的特点: 1)collection实现子类可以存放多个元素,每个元素可以是Object 2)有效Collection的实现类,可以存放重复的元素&#…

Vue.js+SpringBoot开发海南旅游景点推荐系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 用户端2.2 管理员端 三、系统展示四、核心代码4.1 随机景点推荐4.2 景点评价4.3 协同推荐算法4.4 网站登录4.5 查询景点美食 五、免责说明 一、摘要 1.1 项目介绍 基于VueSpringBootMySQL的海南旅游推荐系统&#xff…

MVCC------Mysql并发事务控制的工具

这里写目录标题 一.MVCC是什么二.原理1.隐藏的默认字段2.Undo log3.Undo log版本链4. ReadView 三.回答 一.MVCC是什么 MVCC 是 Multi-Version Concurrency Control(多版本并发控制)的缩写,是数据库系统中常用的一种并发控制方法。在MVCC 中…

高效管理百万级数据:MySQL备份与恢复实战指南

简介 在当今数字化时代,数据是企业不可或缺的核心资产之一,而MySQL作为一种流行的关系型数据库管理系统,其百万级数据的高效管理显得尤为重要。本实战指南将深入探讨MySQL备份与恢复的关键策略,为您提供全面而实用的解决方案。通…

SpringBoot中RestTemplate 发送http请求

SpringBoot中RestTemplate 发送http请求 引入fastjson <!--fastjson--> <dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>2.0.47</version> </dependency>创建配置文件 新建c…

链表中的经典问题——反转链表

经典问题 对于链表的结构还不太清晰的同学&#xff0c;可以看我的另一篇文章&#xff0c;实践总结&#xff1a;一篇搞懂链表——单链表和双指针技巧 反转链表 给你单链表的头节点 head &#xff0c;请你反转链表&#xff0c;并返回反转后的链表。 方法一&#xff0c;迭代法…

牛客周赛 Round 36

赛况 C题可惜&#xff0c;比赛时模拟没有想明白&#xff0c;只对了一半&#xff0c;赛后看了大佬们的题解后恍然大悟&#xff0c;而F题是压根没思路&#xff0c;况且F题部分分也比较难拿。 题目列表 A-小红的数位删除 思路 将读入的数字整除10做三次后输出即可 参考代码 #inc…

【数据结构】详解时间复杂度和空间复杂度的计算

一、时间复杂度&#xff08;执行的次数&#xff09; 1.1时间复杂度的概念 1.2时间复杂度的表示方法 1.3算法复杂度的几种情况 1.4简单时间复杂度的计算 例一 例二 例三 1.5复杂时间复杂度的计算 例一&#xff1a;未优化冒泡排序时间复杂度 例二&#xff1a;经过优化…