为什么你应该使用OpenGL而不是DirectX?

From: http://www.cnblogs.com/Baesky/archive/2011/04/08/2009128.html

这是一篇很意思的博文,原文链接为:http://blog.wolfire.com/2010/01/Why-you-should-use-OpenGL-and-not-DirectX
大家可以思考一下:why we choose a closed source API when the open source is equally good or better?

当我们遇到其他游戏程序员并谈论我们使用OpenGL开发Overgrowth时总是会遇到怀疑的眼神。为什么要用OpenGL? DirectX才是未来。当我们使用OpenGL去告诉显卡如何工作时,房间的温度下降了10度(啥意思?我一直以为A卡和N卡的区别,没想到作者认为是API的问题?Holy。。。)。

OpenGL 是什么?

OpenGL

在1982年,Silicon公司开发售卖使用称为Iris GL的API的高性能图形显示终端。随后的几年,Iris GL变得臃肿和难以维护,直到silicon决定彻底走向新的一步:完全的重构Iris GL并开源。他们的竞争者可以使用这种新的开放图形库(OpenGL)但是作为回报,他们必须帮助维护更新该库。   

如今,OpenGL 由Khronos Group管理。一个由很多公司参与组成的非营利组织,重点是维护高质量多媒体API。在底层,由 OpenGL Architecture Review Board (ARB)来管理。各种游戏平台都支持OpenGL,包括:Mac,Windows,Linux,PS3,Wii,IPhone,PSP和DS,除了XBox,下面我们就要介绍它:

DirectX 是什么?

自从MS-DOS时代,微软就明白游戏是一个用户选择操作系统的重要依据。基于这个原因,在1995年,微软创建了一套专用库以鼓励大家开发winodw95平台独占的游戏。这些库包括Direct3D,DirectInput和DirectSound,整个集合就是大家知晓的DirectX。当微软2001年进军游戏市场时,XBOX意图统治次世代游戏市场。

看看现在的状况,微软的战略无疑是成功的。大多数的PC游戏都是用DirectX,大多都运行在windows或者Xbox360上。但有些例外,它们无法再竞争对手的平台上,比如Playstation, Mac OS和Wii。于是,它给我们带来一个新的问题:

为什么大家都是用 DirectX?

使用DirectX是因为API的选择是基于游戏开发的积极反馈,这一切都发生在2005年:

如果一个API越流行,那就有越多人用,然后它就会更流行,如此循环。。。这种网络效应带来的结果就是:更流行的API获得更好的硬件厂商支持,图形程序员随后更意于选择他们已经熟知的API。

DirectX的胜出得益于微软的两次十分尖锐的战役,围绕XBox360和windows vista,也包括着关于OpenGL这种开源项目都面临着的FUD(恐惧,不确定,怀疑),以及DirectX夸大宣传的优势。从此,这种网络效应将会一步步增强直到OpenGL从地球消失。(作者好悲观。。。)

1. 网络效应与恶性循环

Win平台上,DirectX的图形驱动显然比OpenGL的驱动得到更好的维护。这是由于厂商支持引起的恶性循环。游戏开发者选择是用OpenGL还是DirectX由很多因素决定,显卡厂商得到的OpenGL驱动BUG比较少,因为用DirectX的比较多,所以不能很好的支持OpenGL的驱动。

简单来讲,越多程序员懂得DirectX甚于OpenGL,那么更多游戏使用前者开发。这会引起又一个恶性循环,更多地项目使用DX开发,更多地程序员需要学习如何使用它。。。。

2. 关于 OpenGL的FUD效应 和 Vista

微软在vista发布时对OpenGL使用了FUD战术。在2003年,微软推出了前面介绍维护底层的OARB组织--预示着微软不再会对OPGL的未来感兴趣。在2005年,微软在SIGGRAPH和WinHEC上给大家的假象就是他们从vista开始将不会支持OPGL除了对XP程序的向后兼容。这种版本的OPGL将会建立在DirectX之上,这当然引起严重的性能问题。这场战役导致很多优秀程序员转战DX。

当vista发布后,他又允许厂商创建快速可安装客户端驱动(ICDs)以保留对原生OpenGL的支持。OpenGL发布消息称OpenGL依旧是第一阵营,但是OPGL在vista上的效果始终不如Direct3D。不幸的是,这种破坏已经给OPGL带来了巨大的打击。

3. 误导市场的战役

win7发售时的市场策略与vista如出一辙,微软展示了before和after效果。很多玩家认为从dx9转到dx10就能神奇般的把图形变得更亮,或者说从Halo1变成Crysis。游戏评论证实Crysis的DX9版与DX10无区别,而画面的改变事实上由于调整了某些config文件。

在拥有大量游戏的微软市场策略下,一些有见解的程序员与卡马克大神拒绝追赶他。他说:“个人来讲,我不会立即跳进DX10.我会尝试做些改变直到我真的需要它。”

(我觉得作者是个悲剧,传言说下一代的ID引擎是基于DX的,卡马克也没说不用dx呀。。。)

为什么我们要用 OpenGL?

得到更少的厂商支持,游戏不再大量使用,被微软紧追猛打,市场生存空间狭小,为什么我们还要用它?大家用dx不更省事么?不,因为实际上,OpenGL比DX更强大,支持更多的平台,这是未来游戏的基础。

1. OpenGL 比 DirectX 更强大

OPGL有比DX更快的draw调用(如果你不信请看这里this one),并且它能通过厂商扩展第一时间使用GPU的新特性。OPGL让你能在多平台上直接访问显卡硬件,而DirectX只能在他们最新的操作系统上提供一些最新技术的展示。DX11鼓吹的Tesselation其实三年前就可以用OPGL使用了。我不知道以后还会有什么新技术,但我知道OPGL一定最先可用(这个“卖点”也灰常吸引译者本人)。

2. OpenGL 是跨平台的

暴雪总是同时发布游戏的mac版本,这是他们成功的一项法宝。

就像卡马克被问Rage是不是DX游戏时谈到:“它事实上用的是OpenGL,尽管我们使用了D3D-ish API在Xbox360平台和PS3的CG。你使用的技术很微小一部分,写的上百万行代码只有少数部分才会用API,但是数百万行的代码却依赖那些不可知的目标平台。”就像卡马克说的,为什么不会跨平台做好准备而让自己被DX限制?

3. OpenGL 是未来游戏更好的选择

非盈利的开源OpenGL用于创造一个允许用户在各种平台都能高效能发挥的图形库。他被垄断企业不断攻击,这其实也在伤害您自己的利益。我们需要自由和竞争来提升质量和降低价格。一个微软垄断的局面对游戏开发者和玩家来说都是非常杯具的。

OpenGL 能否力挽狂澜?

回到1997年,那时的情况和现在如此相似。微软为DX发动了疯狂的市场战役,随后大家都“知道”它比OpenGL更快。随着Chirs Hecker发表的open letter denouncing DirectX。情况有所改变。随后,卡马克发布了著名的OpenGL rant,并掏出大把钱用OpenGL开发Id工作室的项目,一度证明了DX不可能达到的3D性能。

这一课已经被渐渐遗忘。很多开发者陷入了dx的市场诱惑。

如果你使用OpenGL,你可以比DX11更早使用更快更强大的显卡特性,并且用于所有版本的windows,mac和linux,同样也可用于PS3,Wii,PSP,DS和iPhone。你也可以在 rapidly-developing WebGL standard使用这些特性(用于次世代网页游戏)。

如果你是一个游戏开发者,你只需搜索资料并思考,然后想想OpenGL是否是更好的选择。

(译后感:本人玩的是C++,这篇文章让我觉得似曾相识,语言之争也从未结束,也将不会结束。API是API,就像卡马克说的,一个游戏很少一部分才用到API。语言呢也终究是工具,所以我们的算法才如此的“泛型”。)


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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

flask web开发的相关博文学习

一、基础教程 flask-tutorial/SUMMARY.md at master greyli/flask-tutorial GitHubThe Flask Mega-Tutorial Part I: Hello, World! - miguelgrinberg.com全面的Flask教程 - 简书Flask入门教程 - HelloFlask 主推miguelgrinberg,课程如下 二、高级应用 flask-sq…

linux c 获取时间戳 打印时间戳

以下是项目开发中常用到的时间戳接口,可以直接用。 一、相关接口 二、代码实现 char* lgw_get_now_time(void) {time_t timep;time(&timep);return asctime(localtime(&timep)); } int lgw_get_now_tick(void) {time_t timep;time(&timep);return ti…

阿里云linux主机安装qt报错:缺少libxkbcommon-x11.so.0

ubuntu云主机安装xfce桌面后,下载qt5.12.10,开发桌面应用,安装qt时报错缺少libxkbcommon-x11.so.0。 由于xfce是轻量级桌面不带libxkbcommon-x11.so.0,而qt5.12.10默认系统已经自带,所以,报错。此时更新一下…

Qt treeWidget 查找指定字段内容的条目并跳转到该条目

遍历Qt treeWidget,查找指定字段内容的条目,并跳转到该条目。 void MainWindow::on_pushButton_sidFind_clicked() {QString sid ui->lineEdit_sidFind->text();QTreeWidgetItemIterator it(ui->treeWidget_sqItem);while (*it) {if ((*it)-&…

SpringMVC之控制器的单例和多例管理

版权声明:本文为博主原创文章,未经博主允许不得转载。 在使用Spring3对控制器Controller进行bean管理时,如果要对控制器是否单例进行管理。 有两种方式配置多例模式: 1.springXML 2.注解本身的控制器类 [java] view plaincopyprin…

BZOJ 1997: [Hnoi2010]Planar( 2sat )

平面图中E ≤ V*2-6..一个圈上2个点的边可以是在外或者内, 经典的2sat问题..------------------------------------------------------------------------------------------#include<cstdio>#include<cstring>#include<algorithm>#include<stack>usin…

Qt6.2.1在线安装教程

1、Qt下载官网 Download Qt | Develop Desktop & Embedded Systems | Qt 2、下载后在线安装 安装时会要求登陆账号&#xff0c;这个可以去官网注册账号。 相关模块和版本按需选择。以下为我的项目开发需要安装的部分模块&#xff1a; 然后漫长等待安装结束即可。

Qt6.2.1使用clang格式化代码

1、环境说明 Qt6.2.1 64bit, windows环境, 安装链接&#xff1a;Download Qt | Develop Desktop & Embedded Systems | Qt llvm 10.0.0 64bit windows环境&#xff0c;安装链接&#xff1a; LLVM Download Page 2、启用Beautifer 帮助--关于插件&#xff0c;勾选Beautif…

Getting Started With Hazelcast 读书笔记(第七章)

第七章 部署策略 Hazelcast具有适应性,能根据不同的架构和应用进行特定的部署配置,每个应用可以根据具体情况选择最优的配置: 数据与应用紧密结合的模式(重点,of就是这种) 胖客户端模式(最好用一种) 轻成员节点模式(折衷上面两种) 1.使用紧密结合的模式&#xff0c;每个JVM实例…

Qt 调用Python引擎混合编程

0、前言 使用Qt和Python做混合编程&#xff0c;充分发挥Qt GUI的图形化框架优势和Python数据处理的计算能力。复杂的计算可用到Python众多三方库&#xff0c;将Python需要执行的功能写成py文件&#xff0c;做成插件的形式&#xff0c;被Qt c调用&#xff0c;修改py文件即可实现…

C# 特性 Attribute

特性就是在类的类名称、属性、方法等上面加一个标记&#xff0c;使这些类、属性、方法等具有某些统一的特征&#xff0c;从而达到某些特殊的需要。举个小栗子&#xff1a;方法的异常捕捉&#xff0c;你是否还在某些可能出现异常的地方&#xff08;例如数据库的操作、文件的操作…

Qt 调用MATLAB引擎混合编程

0、前言 C/C调用MATLAB有三个方式&#xff1a;调用dll文件、调用exe可执行程序和调用Engin引擎。 第一种方式利用MATLAB Coder 将MATLAB代码生成C/C代码和相关动态链接库&#xff0c;可以在没有MATLAB的电脑和设备上运行。 第二种方式利用MATLAB将MATLAB代码编译成exe可执行…

xcode3.2.6升级至4.0.2经验加教训总结(转)

首先&#xff0c;完美运行都项目直接在Xcode4.0.2中build可能会出现这样一个错误&#xff08;人品好的自觉绕道&#xff09;&#xff1a;[BEROR]No architectures to compile for (ARCHSi386, VALID_ARCHS). 首先第一反应是打开工程的Build Settings&#xff0c;最基本的检测&a…

Qt 调用VISA库通过SCPI程控仪器-以IT8906A电子负载为例

SCPI是一种可编程仪器的标准命令&#xff0c;可通过 GPIB&#xff0c; RS232&#xff0c; USB&#xff0c; LAN接口等控制仪器功能的编程语言。 SCPI 置于 IEEE 488.2 硬件部分的顶层。相同 SCPI 命令和参数控制着不同机器的相同功能。一般标准仪器都支持SCPI协议&#xff0c;如…

关于如何使用的MSCS(微软群集服务器)中的iSCSI Guest Initiators (客户机启动器)...

发布者&#xff1a;Dell-Terry Z 作者&#xff1a;戴尔公司 William U 嗨&#xff0c;大家好&#xff01;过去的几周实在太激动人心了。第一届戴尔全球存储论坛&#xff08;Dell Storage Forum&#xff09;刚刚结束&#xff0c;我有一大堆的东西想跟大家分享&#xff0c;我想…

openssl版本信息和支持的命令

1、查看openssl版本 openssl version -a openssl version 可以看到版本信息和安装位置: 2、查看openssl支持的命令 openssl help Standard commands asn1parse ca ciphers cms crl crl2pkcs7 dgst …

栅格像元做地理坐标映射后的坐标值是像元中心点还是其他位置?

做了下实验&#xff0c;GDAL做完映射后像元&#xff08;x&#xff0c;y&#xff09;--->(lat,lon)&#xff0c;得到的坐标值是像元左上角的坐标值。 下面这个看到更清楚&#xff1a;&#xff08;其实我做了一个替换&#xff0c;实际我求的是左上点和右下点&#xff08;通过&…

QT Openssl no OPENSSL_Applink 解决

QT5.15.2安装时候选择了openssl1.1.1库&#xff0c;在开发过程中出现OPENSSL_Applink。 解决办法&#xff1a;将openssl include文件下的applink.c 添加到工程中&#xff0c;即可。

Java学习----运算符与表达式

一.运算符 1.算术运算符 - * / % -- public class Test7 {public static void main(String[] args) {int x 10;int y 3;float f 3.5f;System.out.println(x/y); // 3System.out.println(x%y); // 1System.out.println(x/f); // 2.857143 x隐式转换成floatSystem…

Tomcat 6 数据源配置

近来换了TOMCAT6&#xff0c;配置MYSQL数据库的数据源&#xff0c;在网上查找相关解决方案&#xff0c;后调试解决如下&#xff1a; 修改$CATALINA_HOME/conf/context.xml文件&#xff0c;加入如下代码&#xff1a;<Context reloadable"true"> <Watche…