当前位置: 首页 > news >正文

西安企业建站排名seo搜索引擎优化试题及答案

西安企业建站排名,seo搜索引擎优化试题及答案,前端外包网站,百度排名规则在进行Linux下的图形系统编程时#xff0c;我们常常会遇到以下这些概念#xff1a;Framebuffer, X11, SDL#xff0c;DFB, miniGUI, OpenGL#xff0c;QT, GTK#xff0c;KDE, GNOME等等。一、Linux 图形领域的基础设施1.1 X WindowX Window从逻辑上分为三层#xff1a;X…在进行Linux下的图形系统编程时我们常常会遇到以下这些概念Framebuffer, X11, SDLDFB, miniGUI, OpenGLQT, GTKKDE, GNOME等等。一、Linux 图形领域的基础设施1.1 X WindowX Window从逻辑上分为三层X Server、X Client和X协议。最底层的X Server(X服务器)主要处理输入/输出信息并维护相关资源它接受来自键盘、鼠标的操作并将它交给X Client(X客户端)作出反馈而由X Client传来的输出信息也由它来负责输出最上层的X Client则提供一个完整的GUI界面负责与用户的直接交互(KDE、GNOME都是一个X Client)。X协议则是衔接X Server与X Client的通讯协议它的任务是充当这两者的沟通管道。尽管UNIX厂商采用相同的X Window但终端的X Client并不相同。XFree86是X Window系统的一个开源的实现。它主要运行于Unix以及类Unix操作系统上。XFree86在显示硬件(鼠标、键盘以及显卡)与桌面环境(也就是窗口管理器)之间提供了一个Client/Server接口。1.2 SVGALibSVGALib是Linux下的底层图形库也是Linux系统中最早出现的非X图形支持库它支持标准的VGA图形模式和一些其他的模式SVGALib的缺点是程序必须以root权限登录并且它是基于图形卡的所以不是所有的硬件都支持它。自从framebuffer这个孪生姐妹诞生后许多软件由只支持SVGALib变为同时支持两者甚至一些流行的高层函数库如QT 和GTK只支持Framebuffer作为一个老的图形支持库SVGALib目前的应用范围越来越小尤其是在 Linux 内核增加了FrameBuffer驱动支持之后。1.3 FrameBufferFrameBuffer是出现在Linux 2.2.xx内核当中的一种驱动程序接口。这种接口将显示设备抽象为帧缓冲区。用户可以将它看成是显示内存的一个映像将其映射到进程地址空间之后就可以直接对显存进行读写操作而写操作可以立即反映在屏幕上。该驱动程序的设备文件一般是/dev/fb0、/dev/fb1 等等。在应用程序中一般通过将FrameBuffer设备映射到进程地址空间的方式来使用比如下面的程序就打开/dev/fb0设备并通过mmap系统调用进行地址映射随后用memset将屏幕清空(这里假设显示模式是1024x766-8位色模式线性内存模式)FrameBuffer设备还提供了若干ioctl命令通过这些命令可以获得显示设备的一些固定信息(比如显示内存大小)、与显示模式相关的可变信息(比如分辨率、象素结构、每扫描线的字节宽度)以及伪彩色模式下的调色板信息等等。FrameBuffer实际上只是一个提供显示内存和显示芯片寄存器从物理内存映射到进程地址空间中的设备。所以对于应用程序而言如果希望在FrameBuf之上进行图形编程还需要完成其他许多工作。FrameBuffer 就像一张画布用什么样子的画笔如何画画还需要你自己动手完成。1.4 LibGGILibGGI试图建立一个一般性的图形接口而这个抽象接口连同相关的输入(鼠标、键盘、游戏杆等)抽象接口一起可以方便地运行在X Window、SVGALib、FrameBuffer等等之上。建立在LibGGI之上的应用程序不需重新编译就可以在上述这些底层图形接口上运行。但不知何故LibGGI的发展几乎停滞。二、Linux 图形领域的高级函数库2.1 Xlib及其他相关函数库在X Window系统中进行图形编程时可以选择直接使用Xlib。Xlib实际上是对底层X协议的封装可通过该函数库进行一般的图形输出。如果你的X Server支持DGA则可以通过DGA扩展直接访问显示设备从而获得加速支持。对一般用户而言由于Xlib的接口太原始而且复杂因此一般的图形程序选择其他高级一些的图形库作为基础。比如GTK、QT 等等。这两个函数库同时还是一些高级的图形用户界面的支持函数库。由于种种原因GTK、QT等函数库存在庞大、占用系统资源多的问题不太适合在嵌入式系统中使用。这时你可以选择使用 FLTK这是一个轻量级的图形函数库但它的主要功能集中在用户界面上提供了较为丰富的控件集。2.2 SDLSDL(Simple DirectMedia Layer)是一个跨平台的多媒体游戏支持库。其中包含了对图形、声音、游戏杆、线程等等的支持目前可以运行在许多平台上其中包括 X Window、X Window with DGA、Linux FrameBuffer控制台、Linux SVGALib以及Windows DirectX、BeOS 等等。因为SDL是专门为游戏和多媒体应用而设计开发所以它对图形的支持非常优秀尤其是高级图形能力比如Alpha混和、透明处理、YUV覆盖、Gamma 校正等等。而且在SDL环境中能够非常方便地加载支持OpenGL的Mesa库从而提供对二维和三维图形的支持。可以说SDL是编写跨平台游戏和多媒体应用的最佳平台也的确得到了广泛应用。相关信息可参阅 http://www.libsdl.org/。2.3 AllegroAllegro是一个专门为x86平台设计的游戏图形库。最初的Allegro运行在 DOS环境下而目前可运行在Linux FrameBuffer控制台、Linux SVGALib、X Window等系统上。Allegro提供了一些丰富的图形功能包括矩形填充和样条曲线生成等等而且具有较好的三维图形显示能力。由于Allegro的许多关键代码是采用汇编编写的所以该函数库具有运行速度快、资源占用少的特点。然而Allegro也存在如下缺点1)对线程的支持较差。Allegro的许多函数是非线程安全的不能同时在两个以上的线程中使用。2)对硬件加速能力的支持不足在设计上没有为硬件加速提供接口。有关 Allegro 的进一步信息可参阅http://www.allegro.cc/。2.4 Mesa3DMesa3D是一个兼容OpenGL规范的开放源码函数库是目前Linux上提供专业三维图形支持的惟一选择。Mesa3D同时也是一个跨平台的函数库能够运行在X Window、X Window with DGA、BeOS、Linux SVGALib 等平台上。2.5 DirectFBDirectFB是专注于Linux FrameBuffer硬件加速的一个图形库并试图建立一个兼容GTK的嵌入式GUI系统。它以可装载函数库的形式提供对加速 FrameBuffer驱动程序的支持。目前该函数库正在开发之中(最新版本 0.9.97)详情可见 http://www.directfb.org/。三、面向嵌入式Linux系统的图形用户界面3.1 MicoroWindows/NanoXMicroWindows(http://microwindows.censoft.com/)是一个开放源码的项目目前由美国Century Software公司主持开发。该项目的开发一度非常活跃国内也有人参与了其中的开发并编写了GB2312等字符集的支持。但在 Qt/Embedded发布以来该项目变得不太活跃并长时间停留在0.89Pre7版本。可以说以开放源码形势发展的MicroWindows项目已基本停滞。MicroWindows是一个典型的基于客户/服务器体系结构的GUI系统基本分为三层。最底层是面向图形输出和键盘、鼠标或触摸屏的驱动程序中间层提供底层硬件的抽象接口并进行窗口管理最高层分别提供兼容于X Window和 Windows CE(Win32 子集)的API。该项目的主要特色在于提供了类似X的客户/服务器体系结构并提供了相对完善的图形功能包括一些高级的功能比如Alpha混合三维支持TrueType 字体支持等。但需要注意的是MicroWindows的图形引擎存在许多问题可以归纳如下1)无任何硬件加速能力。2)图形引擎中存在许多低效算法同时未经任何优化。比如在直线或者圆弧绘图函数中存在低效的逐点判断剪切的问题。3)代码质量较差。由于该项目缺少一个强有力的核心代码维护人员因此代码质量参差不齐影响整体系统稳定性。这也是MicroWindows长时间停留在 0.89Pre7 版本上的原因。MicroWindows 采用MPL条款发布(该条款基本类似 LGPL 条款)。3.2 OpenGUIOpenGUI(http://www.tutok.sk/fastgl/)在Linux系统上存在已经很长时间了。最初的名字叫FastGL只支持256色的线性显存模式但目前也支持其他显示模式并且支持多种操作系统平台比如 MS-DOS、QNX 和Linux等等不过目前只支持x86硬件平台。OpenGUI也分为三层。最低层是由汇编编写的快速图形引擎中间层提供了图形绘制API包括线条、矩形、圆弧等并且兼容于 Borland的BGI API。第三层用C编写提供了完整的GUI对象集。OpenGUI采用LGPL条款发布。OpenGUI比较适合于基于x86平台的实时系统可移植性稍差目前的发展也基本停滞。3.3 Qt/EmbeddedQt/Embedded是著名的Qt库开发商TrollTech(http://www.trolltech.com/)发布的面向嵌入式系统的Qt版本。因为Qt是KDE等项目使用的GUI支持库所以有许多基于Qt 的X Window程序可以非常方便地移植到Qt/Embedded版本上。因此自从Qt/Embedded以GPL条款形势发布以来就有大量的嵌入式Linux开发商转到了Qt/Embedded系统上。比如韩国的Miz 公司台湾省的某些嵌入式Linux应用开发商等等。不过在笔者看来Qt/Embedded还有一些问题值得开发者注意1)目前该系统采用两种条款发布其中包括GPL条款。对函数库使用GPL条款意味着其上的应用需要遵循GPL条款。当然了如果要开发商业程序TrollTech也允许你采用另外一个授权条款这时就必须向TrollTech交纳授权费用了。2)Qt/Embedded是一个C函数库尽管Qt/Embedded声称可以裁剪到最少 630K但这时的Qt/Embedded库已经基本上失去了使用价值。低的程序效率、大的资源消耗也对运行Qt/Embedded的硬件提出了更高的要求。3)Qt/Embedded库目前主要针对手持式信息终端因为对硬件加速支持的匮乏很难应用到对图形速度、功能和效率要求较高的嵌入式系统当中比如机顶盒、游戏终端等等。4)Qt/Embedded提供的控件集风格沿用了PC风格并不太适合许多手持设备的操作要求。5)Qt/Embedded的结构过于复杂很难进行底层的扩充、定制和移植尤其是那个用来实现signal/slot机制的著名的moc文件。因为上述这些原因目前所见到的Qt/Embedded 的运行环境几乎是清一色基于StrongARM的iPAQ。注目前Qt/Embedded已经增加了对DirectFB驱动的支持因此具有了图形加速能力其性能也大大地得到提高。3.4 MiniGUIMiniGUI(http://www.minigui.org/)是由许多自由软件开发人员支持的一个自由软件项目(遵循 LGPL 条款发布)其目标是为基于Linux 的实时嵌入式系统提供一个轻量级的图形用户界面支持系统。该项目自 1998 年底开始到现在已历经3年多的开发过程。到目前为止已经非常成熟和稳定。目前已经正式发布了稳定版本 1.0.9并且开始了新版本系列的开发即 MiniGUI Version 1.1.x该系列的正式版也即将发布。在MiniGUI几年的发展过程中有许多值得一提的技术创新点正是由于这些技术上的创新才使得 MiniGUI 更加适合实时嵌入式系统而且 MiniGUI 的灵活性非常好可以应用在包括手持设备、机顶盒、游戏终端等等在内的各种高端或者低端的嵌入式系统当中。这些技术创新包括1)图形抽象层。图形抽象层对顶层 API 基本没有影响但大大方便了 MiniGUI 应用程序的移植、调试等工作。目前包含三个图形引擎SVGALib、LibGGI 以及直接基于 Linux FrameBuffer 的 Native Engine利用 LibGGI 时可在 X Window 上运行 MiniGUI 应用程序并可非常方便地进行调试。与图形抽象层相关的还有输入事件的抽象层。MiniGUI 现在已经被证明能够在基于 ARM、MIPS、StrongARM 以及 PowerPC 等的嵌入式系统上流畅运行。2)多字体和多字符集支持。这部分通过设备上下文(DC)的逻辑字体(LOGFONT)实现不管是字体类型还是字符集都可以非常方便地进行扩充。应用程序在启动时可切换系统字符集比如 GB、BIG5、EUCKR、UJIS。利用 DrawText 等函数时可通过指定字体而获得其他字符集支持。对于一个窗口来说同时显示不同语种的文字是可能的。MiniGUI 的这种字符集支持不同于传统通过 UNICODE 实现的多字符集支持这种实现更加适合于嵌入式系统。3)两个不同架构的版本。最初的 MiniGUI 运行在 PThread 库之上这个版本适合于功能单一的嵌入式系统但存在系统健壮性不够的缺点。在 0.9.98 版本中我们引入了 MiniGUI-Lite 版本这个版本在提高系统健壮性的同时通过一系列创新途径避免了传统 C/S 结构的弱点为功能复杂的嵌入式系统提供了一个高效、稳定的 GUI 系统。在 MiniGUI 1.1.0 版本的开发中我们参照 SDL 和 Allegro 的图形部分重新设计了图形抽象层并增强了图形功能同时增强了 MiniGUI-Lite 版本的某些特性。这些特性包括1)MiniGUI-Lite 支持层的概念。同一层可容纳多个能够同时显示的客户程序并平铺在屏幕上显示。2)新的 GAL 能够支持硬件加速能力并能够充分使用显示内存新 GAL 之上的新 GDI 接口得到进一步增强。新的 GDI 接口可以支持 Alpha 混和、透明位块传输、光栅操作、YUV覆盖、Gamma 校正以及高级图形功能(椭圆、多边形、样条曲线)等等。MiniGUI 新版本在图形方面的增强和提高将大大扩展它的应用领域希望能够对嵌入式 Linux 上的多媒体应用、游戏开发提供支持。纵观嵌入式 Linux 系统上的各种图形系统方案我们发现许多图形系统(如 Qt/Embedded 和 MicoroWindows)只注重手持设备上的需求却不太注重其他应用领域的需求而其他许多需要图形支持的嵌入式 Linux 系统却需要许多独特的、高级的图形功能而不仅仅是图形用户界面。为此在接下来的开发中我们还将在如下领域继续开发 MiniGUI1)提供运行在 MiniGUI上的 JAVA 虚拟机 AWT 组件的实现。2)提供 MiniGUI 上的OpenGL 实现。3)提供类QT 控件集的C 封装。3)提供窗口/控件风格主题支持。4)在 MiniGUI-Lite 当中增加对矢量字体的支持。四、Linux/Unix系统图形界面原理简单介绍及GTK、QT、GNOME和KDE的关系最近IT新闻出现较多的就是诺基亚的新版手机操作系统Symbian 3。今天看到在cnbeta上看大家为这个系统争论不休其焦点也逐渐转移到到塞班新系统的核心技术Qt 。评论区大家唇枪舌战不过很多人连基本概念都没搞明白今天正好无事可做稍微整理下X11,GTK,QT,GNOMEKDE的区别与联系。一、在这之前你必须要了解1.linux是基于Unix的2.塞班Symbian、苹果max os等系统的最底层也是unix3.linux本身没有图形界面,linux现在的图形界面的实现只是linux下的应用程序实现的4.Xwindow、Xfree中的X是协议,不是具体的某个软件5.linux图形界面层次关系linux本身--X服务器窗口管理器(综合桌面环境)--X应用程序二、linux和windows下界面系统的区别图形界面并不是linux的一部分 ,linux只是一个基于命令行的操作系统,linux和Xfree的关系就相当于当年的DOS和 WINDOWS3.0一样,windows3.0不是独立的操作系统,它只是DOS的扩充,是DOS下的应用程序级别的系统,不是独立的操作系统,同样 XFree只是linux下的一个应用程序而已.不是系统的一部分,但是X的存在可以方便用户使用电脑.WINDOWS95及以后的版本就不一样了,他们 的图形界面是操作系统的一部分,图形界面在系统内核中就实现了,没有了图形界面windows就不成为windows了,但linux却不一样,没有图形界面linux还是linux,很多装linux的WEB服务器就根本不装X服务器。这也WINDOWS和linux的重要区别之一。三、关于linux两大图形界面KDE和GnomeKDE早于Gnome出现但是KDE基于的Qt是不遵循GPL开源协议的Qt是一个跨平台的C图形用户界面库 它是挪威TrollTech公司的产品(2008年底被NOKIA收购)。 Qt具有优良的跨平台特性(支持Windows、Linux、各种UNIX、OS390和QNX等)、面向对象机制以及丰富的API同时也可支持2D/3D渲染和OpenGL API。在当时的同类图形用户界面库产品中Qt的功能最为强大.但底层的基础 Qt却是一个不遵循GPL的商业软件这就给KDE上了一道无形的枷锁并带来可能的法律风险。一大批自由程序员对KDE项目的决定深为不满它们认为利用非自由软件开发违背了GPL的精神。于是这些GNU的狂热信徒兵分两路其中一部分人去制作Harmonny试图重写出一套兼容Qt的替代品这个项目虽然技术上相对简单但却没有获得KDE项目的支持另一路人马则决定重新开发一套名为“GNOME(GNU Network Object Environment)”的图形环境来替代KDE。GNOME选择完全遵循GPL的GTK图形界面库为基础因此我们也一般将GNOME和KDE两大阵营称为GNOME/GTK和 KDE/Qt。与Qt基于C语言不同GTK采用较传统的C语言 虽然C语言不支持面向对象设计看起来比较落后但当时熟悉C语言的开发者远远多于熟悉C的开发者。加之GNOME/GTK完全遵循GPL版权公约吸引了更多的自由程序员参与。四、linux/unix基于X window的图形显示处理原理X Window从逻辑上分为三层最底层的X Server(X服务器)主要处理输入/输出信息并维护相关资源它接受来自键盘、鼠标的操作并将它交给X Client(X客户端)作出反馈而由X Client传来的输出信息也由它来负责输出最外层的X Client则提供一个完整的GUI界面负责与用户的直接交互(KDE、Gnome都是一个X Client)而衔接X Server与X Client的就是“X Protocol(X通讯协议)”、它的任务是充当这两者的沟通管道。尽管UNIX厂商采用相同的X Window但终端的X Client并不相同。五、Qt、GTK 和KDE、GNOME的关系简单来说为了方便开发人员编写X clients就有了Xlib来封装X协议Xlib还不够方便于是就有了qt和gtk它们提供了很多窗口控件(widgets)。为了方便用户 就出现了gnome和kde等桌面管理系统。一般来说linux用户看到的界面就是其中之一了。gnome用的是gtk库kde用的是qt库。
http://www.huolong8.cn/news/250255/

相关文章:

  • 网站开发制作全包discover wordpress
  • 网站2级目录怎么做工程建设概况
  • 网站运营管理的内容有哪些定制的网站源码
  • 网站建设哪里有win2003 网站服务器
  • 基金会网站模板域名注册完成后怎么做网站
  • 班级设计网站建设手机网站 app
  • 如何用电子邮箱做网站公众号后端框架
  • 深圳模具外贸网站建设企业所得税优惠政策最新2021年
  • 福建省建设信息网站手机网页打不开但是有网什么原因
  • 湖南网站推高校网站设计方案
  • 网站如何优化推广网络seo外包
  • 典型的网站案例做网站开发还会有前途吗
  • 豪柏大厦做网站的公司广州站在哪里
  • 网站建设赵玉敏江阴住房和城乡建设局网站
  • 成都网站设计建设推荐网站怎么做快推广方案
  • 建设厅网站上报名班级网站开发环境
  • 做恋视频网站上海徐汇区网站建设
  • 如何建设自己的网站 知乎网站竞争对手
  • 创办一个网站需要多少费用wordpress小程序写文章
  • 个人网站平台搭建如何建个人微信公众号
  • 怎么接网站建设的单子大型视频网站开发
  • html5网站怎么建设后台怎么弄网站建设有哪三部
  • 企业申报网站wordpress圆圈特效
  • 电商门户网站长春做网站哪个公司好
  • 网站如何做微信支付宝支付宝dz论坛识别手机网站自动跳转
  • 网站seo心态纪念馆网站建设方案
  • 公司网站开发费用如何做账wordpress后台安全
  • 安阳企业建网站青岛网站关键词
  • 好网站建设公司报价化妆品推广软文
  • 政务网站建设云计算中心阿里云企业网站怎么建设