Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >如何在没有OpenGL的情况下绘制到显示器上?

如何在没有OpenGL的情况下绘制到显示器上?
EN

Stack Overflow用户
提问于 2020-05-14 19:02:51
回答 3查看 520关注 0票数 2

我一直在学习OpenGL,当我坐下来尝试编写我的VBO、PBO、VAO、纹理、四边形、绑定、片段着色器、顶点着色器和其他一整套经过几十年发展的抽象的现代抽象时,我在想:显示器不就是一个很大的内存块吗?

我听说过这样的故事,在“好日子”(比如Commodore 64)中,你所要做的就是给内存中的任意一个字节赋值,屏幕就会改变一个像素。非常简单和优雅。在现代,这种情况已经随着一层又一层的抽象和保障而改变,比如改变显示器上的一个像素需要几百英尺的距离。

这就引出了一个问题,在现代社会,仅仅“更新屏幕的一个像素”是可能的吗?是否有可能编写我自己的图形驱动程序或其他东西,在那里我可以发送命令到一些与GPU接口的C包装器来更改这些像素?这是一个非常广泛的问题,但我很好奇。我正在寻找的这个问题的答案将提供一个粗略的轮廓,你必须能够做什么,以便能够任意地让一些C代码在屏幕上设置一个像素,以及为什么OpenGL取得了今天的进展-VBO,PBO,VAO,绑定,着色器等解决了什么问题,以及我们是如何走到今天的位置的。

EN

回答 3

Stack Overflow用户

发布于 2020-05-19 20:48:21

您可以创建自己的帧缓冲区--这只是一个整数数组--并对其进行光栅化,然后使用例如Windows GDI函数SetBitmapBits()将其一次性绘制到显示器上。最终的绘图到显示命令取决于操作系统。

如何在帧缓冲区上进行光栅化完全由您决定。您可以使用CPU来绘制单独的像素或光栅化线条和三角形,例如,请参阅我的使用Windows GDI的旧CPU图形引擎的演示:https://youtu.be/GFzisvhtRS4。只要不栅格化大型数据集,使用CPU就可以。根据我的经验,在CPU上实时60fps渲染的限制是每帧约50k行。

如果你想栅格化非常大的数据集,你必须以某种方式使用GPU。由于帧缓冲区只是一个整数数组,您可以使用OpenCL或CUDA将其传输到GPU或从GPU传输它,并且在GPU上-如果您的数据集恰好已经在视频内存中-并行地执行所有光栅化。为此,您将需要一个额外的z缓冲区来决定哪些像素要通过遮挡几何图形进行透绘。通过这种方式,您可以以60fps的速度栅格化大约每帧3000万行。此演示使用OpenCL:https://youtu.be/lDsz2maaZEo在图形处理器上实时呈现

票数 1
EN

Stack Overflow用户

发布于 2020-05-14 19:26:19

在现代有可能只“更新屏幕的一个像素”吗?

是。例如,在Windows中,您可以使用SetPixel()绘制像素,也可以使用BitBlt()批量绘制。请参阅this Q/A

这可以很好地工作,但这意味着你正在使用CPU进行渲染,你会发现GPU对这项任务更有效,特别是当你需要像样的帧率和非平凡的图形时。之所以有这些“一整套基于抽象的其他现代抽象”是为了充当GPU的接口,因为它有一组独立的内存和完全不同的执行模型。其他GPU库(OpenCL、DirectX、Vulkan等)都有相同类型的抽象。

我已经忽略了许多细微差别,但我希望大家都能理解这一点。

票数 0
EN

Stack Overflow用户

发布于 2020-05-14 19:35:15

不就是一个很大的内存块吗?

是的,它被称为帧缓冲区。

我听说过这样的故事:在“美好时光”(good of‘days)中(比如Commodore 64)

当你打开电源时,你现在的电脑就是这样工作的!如果使用CPU写入视频内存,则称为软件渲染器。

在现代,这种情况已经随着一层又一层的抽象和安全措施而改变,比如改变显示器上的一个像素需要几百英尺的距离。

不,它们不是“改变像素”的抽象/保护。如今,不再使用软件渲染器。相反,您必须告诉GPU (这是另一台独立的计算机)如何绘图。这就是API(如OpenGL)为您做的事情。

现在,GPU意味着绘图速度很快,这就需要专门的代码和数据结构。这些都是你提到的东西:VBO,PBO,VAO,着色器,等等(用OpenGL的说法)。这是没有办法的,因为GPU是不同的硬件。

在现代有可能只“更新屏幕的一个像素”吗?

是的,但这最终会被GPU以某种方式绘制出来,即使它看起来像是内存写入。

是否有可能编写我自己的图形驱动程序或其他东西,在那里我可以发送命令到一些C包装器,它与图形处理器接口,以改变这些像素?

是的,但那个"C包装器“就是图形驱动程序。现代GPU的图形驱动程序非常复杂。

为了能够任意获得一些C代码来在屏幕上设置像素而必须做的事情

您不能编写"C程序“来写入图形屏幕,因为C标准本身并不关心图形显示。

所以这取决于你的操作系统,你的硬件,你是否想要2D或3D加速支持,你选择的API…

以及为什么OpenGL取得今天的进展的大致轮廓-VBO、PBO、VAO、绑定、着色器等解决了什么问题,以及我们是如何走到今天的位置的。

请参见上面的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61805409

复制
相关文章
关于图中节点间的概率求解问题
(本文年代久远,请谨慎阅读)前提:节点是含有若干特征(小节点)的大节点,大节点间连接实际为特征间的连接
ZONGLYN
2019/08/08
8580
Gephi节点颜色、大小、标签颜色和大小以及边排序。
1、点击[文件] 2、点击[生成] 3、点击[随机图] 4、点击[确定] 5、点击[大小] 6、点击[10] 7、点击[应用] 8、点击[颜色] 9、点击[Ranking] 10、点击[选择一种渲染方式] 11、点击[度] 12、点击[应用] 13、点击[颜色] 14、点击[默认] 15、点击[颜色] 16、点击[应用] 17、点击[颜色] 18、点击[颜色] 19、点击[OK] 20、点击[应用] 21、点击[大小]
裴来凡
2022/05/28
8.7K0
Gephi节点颜色、大小、标签颜色和大小以及边排序。
matplotlib画图中的各种设置
原文出处:https://www.jianshu.com/p/8006d74ac9e7
SL_World
2021/09/18
2.8K0
添加标签——给定标签选项
HTML: 1 <h3>haveTags</h3> 2 <div id="havetags"></div> 3 <hr /> 4 <h3>addTags</h3> 5 <div id="addtags"></div> 6 <button id="btn">返回的数组</button> CSS: 1 #havetags span, 2 #addtags span { 3 display: inline-block; 4 padding:
ProsperLee
2018/10/24
8870
添加标签——给定标签选项
识别图中的图形形状,颜色,位置,面积,周长。
1、点击[Matlab] 2、点击[命令行窗口] 3、按<Enter>键
裴来凡
2022/05/28
1.2K0
识别图中的图形形状,颜色,位置,面积,周长。
添加标签——无给定标签选项
HTML: 1 <!-- input输入标签,请以英文逗号分开 --> 2 <input type="text" placeholder="请以英文逗号分开" id="tagvalue" value="Prosper,Lee,无敌,的,存在" /> 3 4 <!-- 添加标签 --> 5 <button id="addbtn">无标签选项的添加标签</button> 6 7 <hr /> 8 9 <!-- 添加标
ProsperLee
2018/10/24
7630
添加标签——无给定标签选项
Python OpenCV查找图中的四边形/矩形
F:\opencv4.2_release\opencv\sources\samples\python\squares.py
Color Space
2020/08/06
16.3K1
任意位置删除节点
删除任意位置节点和添加任意位置节点其实差不多,都是要先找到n-1的位置,然后进行下一步的操作。 唯一有区别的是,需要用断开链接之后,需要用free把节点在堆上的内存清理掉。
用户7272142
2023/10/11
1570
任意位置删除节点
在指定位置按照需要在接边处进行融合
想法来源于某技术交流群,有朋友问起,如何可以进行这些数据的合并?这些数据,其实就是互联网电子地图中的建筑物轮廓,由于切片等原因,下载的数据都是分块的,而在实际使用中往往需要进行融合。
数据处理与分析
2019/07/31
6332
在指定位置按照需要在接边处进行融合
链表任意位置插入节点
之前我们的链表代码只能从头部插入节点,也就是通过修改head指向新节点,然后新节点指向head之前指向的节点达到增加头节点的目的。
用户7272142
2023/10/11
1890
链表任意位置插入节点
「微软」局部图协同过滤缓解数据稀疏问题
本文是针对图神经网络在推荐系统中的应用提出的相关方法LGCF,对于用户-商品交互数据稀疏的情况下,无法得到较好的embedding来计算偏好。LGCF不需要为每个用户和商品学习embedding,旨在将有用的 CF 信息编码到局部图中,并基于该图进行推荐。
秋枫学习笔记
2022/09/19
6930
Docsify 的边栏目录如何设置
如下图中的文档中的 docsify 边栏是如何设置的? 配置方法 在你的项目的 index.html 文件中,添加参数: loadSidebar: true 然后再在项目中添加一个 _sidebar.md 文件,这个文件的格式为: - CWIKIUS 文档概述 - [文档介绍和快速链接](README.md) - [公众平台](CONTACT.md) - Gradle - [Deploy](deploy.md) - 其他小工具 - [JWT](jwt/README.md) -
HoneyMoose
2020/11/29
1.3K0
Docsify 的边栏目录如何设置
input内文字与光标的初始位置调整
input {     /*方法一*/     text-align = center; /*placeholder文字居中*/     text-align = left; /*placeholder文字居左*/     text-align = right; /*placeholder文字居右*/     /*方法二*/     padding-left:10px; /*placeholder文字距左10px*/     padding-right:10px; /*placeholder文字距右10px
似水的流年
2020/09/10
3.7K0
ICLR2020 | CS-GNN:用平滑度刻画图信息的使用
今天给大家介绍香港中文大学和新加坡国立大学一起在ICLR2020上发布的一篇论文,该论文针对实际使用中GNN在图结构数据中能够获得多少性能的问题,提出了两种可以度量从图中获取的信息的数量和质量的平滑度指标,以及一个使用上述平滑度指标的GNN框架CS-GNN。实验显示,在不同类型的图上,对于特定任务而言,CS-GNN相比于现有的模型有更好的效果。
DrugAI
2021/02/01
8130
ICLR2020 | CS-GNN:用平滑度刻画图信息的使用
【CSS】CSS 背景设置 ② ( 背景位置 | 背景位置-方位值设置 )
background-position 属性值 可以是 length 长度 , 也可以是 position 方位 ;
韩曙亮
2023/03/30
4.1K0
【CSS】CSS 背景设置 ② ( 背景位置 | 背景位置-方位值设置 )
老大的位置还能坐多久?比特币“江湖地位”创历史新低
企鹅号小编
2018/01/04
5490
老大的位置还能坐多久?比特币“江湖地位”创历史新低
图神经网络的自监督学习
当标记样本有限时,作为一种利用大量未标记样本的新范式, 自监督学习(Self-Supervised Learning,SSL)正在兴起。SSL在自然语言和图像学习任务上取得了很好的性能。最近,有一种趋势是使用图神经网络将这种成功扩展到图数据。
智能生信
2021/04/13
1.6K0
图神经网络的自监督学习
在目标检测中如何解决小目标的问题?
在深度学习目标检测中,特别是人脸检测中,由于分辨率低、图像模糊、信息少、噪声多,小目标和小人脸的检测一直是一个实用和常见的难点问题。然而,在过去几年的发展中,也出现了一些提高小目标检测性能的解决方案。本文将对这些方法进行分析、整理和总结。
公众号机器学习与AI生成创作
2021/04/30
1.5K0
在目标检测中如何解决小目标的问题?
图表的标签显示设置
腾讯云商业智能分析产品由北京永洪商智科技有限公司提供,永洪BI-一站式大数据分析平台 图表标签设置是编辑报告中常见的操作,这里说一下图表标签设置的常见问题。图表标签显示设置具有一定的通用性,这里以柱
腾讯云商业智能分析团队
2017/08/28
2.8K0
图表的标签显示设置
点击加载更多

相似问题

在画布上打印div

10

在div上覆盖画布

10

在画布上绘画并自动删除它(HTML5)

21

在画布上绘图,添加贴纸,定制位图- Android

13

联合所有并维护活动记录关系?

18
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档