OpenGL- 从创建窗口开始

创建窗口

前言

下面的点。描述了创建窗口的重要性和一些理解

  • 所有系统的app开发都是从创建窗口开始的
  • 窗口是一个底层的抽象概念
  • 这一节对理解各系统的渲染机制比较关键。因为对android较为了解,故常用android举例,
  • android创建window也会用到opengl的api
  • 从这一点出发可以做很多兼容性/跨平台的顶层描述语言(DSL),比如compose mult,Filament。
  • opengl创建窗口也一样,不同的系统,有不同的创建方式。GLFW帮我们做了这个适配逻辑

那么我们先看GLFW

GLFW github.com/glfw/glfw

编译是熟悉的过程,这部分我就不介绍了,万事开头难,请认真对待哦。

下面是创建窗口的几个关键点

  • width, height
  • viewport
  • 考虑了一些兼容性问题

核心代码如下:

kotlin 复制代码
// 初始化库
glfwInit();
// 一些兼容性代码
glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 3);
glfwWindowHint(GLFW_CONTEXT_VERSION_MINOR, 3);
glfwWindowHint(GLFW_OPENGL_PROFILE, GLFW_OPENGL_CORE_PROFILE);
glfwWindowHint(GLFW_RESIZABLE, GL_FALSE);
glfwWindowHint(GLFW_OPENGL_FORWARD_COMPAT, GL_TRUE);
// 创建窗口
GLFWwindow *window = glfwCreateWindow(800, 600, "LearnOpenGL", nullptr, nullptr);
if (window == nullptr) {
    std::cout << "Failed to create GLFW window" << std::endl;
    glfwTerminate();
    return -1;
}
glfwMakeContextCurrent(window);

// 创建视口
int width, height;
glfwGetFramebufferSize(window, &width, &height);
glViewport(0, 0, width, height);
  • 800 , 600是显示器的分辨率
  • glfwMakeContextCurrent 设置上下文
  • viewport,可理解为视口,就是真正使用opengl绘制的区域

结果如下:
💡 思考:为啥需要window → viewport 这两层?

这两层的关系类型于android中的window → surface

Filament是如何做到兼容github.com/google/fila...

Filament是一个实时的基于物理的渲染引擎,适用于Android, iOS, Linux, macOS, Windows和WebGL。

  • 顶层DSL语言(如JAVA,SWIFT等)创建 nativewindow, 下发到底层的,创建一个缓冲层(swapChain)处理双缓冲问题。后续opengl 绘制都忘swapChain insert buffer
  • 下图可以看到swapchain有很多实现。后续所有的调用和渲染是独立的 ,使用filament api的调用,都会走到filament渲染引擎
相关推荐
NiceCloud喜云8 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
wordbaby9 小时前
React Native + RNOH:跨页面数据回传的最佳实践与避坑指南
前端·react native
丷丩9 小时前
MapLibre GL JS第22课:查看本地GeoJSON
前端·javascript·map·mapbox·maplibre gl js
Front思10 小时前
AI前端工程师需要具备能力+
前端·人工智能·ai
ZC跨境爬虫12 小时前
跟着 MDN 学CSS day_29:(掌握文本与字体样式的核心艺术)
前端·css·ui·html·tensorflow
李子琪。12 小时前
网络空间安全深度实战:CSRF 漏洞原理剖析与基于 Token 的纵深防御体系构建(全栈实验报告)
前端·安全·csrf
冰暮流星12 小时前
javascript之history对象介绍
前端·笔记
IT_陈寒13 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端
丷丩13 小时前
MapLibre GL JS第19课:实时更新要素
前端·javascript·gis·map·mapbox·maplibre gl js
Mr.Daozhi13 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具