• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            逛奔的蝸牛

            我不聰明,但我會很努力

               ::  :: 新隨筆 ::  ::  :: 管理 ::
            Antialiasing 
            Another use for OpenGL’s blending capabilities is antialiasing. 
            Turning on antialiasing is simple. 
            First: you must enable blending and set the blending function.
            glEnable(GL_BLEND);
            glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);

            Second: choose to antialias points, lines, and/or polygons(any solid primitive) by  calling glEnable:
            glEnable(GL_POINT_SMOOTH);  // Smooth out points.(smooth out: 使平滑)
            glEnable(GL_LINE_SMOOTH); // Smooth out lines.
            glEnable(GL_POLYGON_SMOOTH); // Smooth out polygon edges.

            Third: give hint to do the best job possible:
            glHint(GL_POLYGON_SMOOTH_HINT, GL_NICEST);


            Solid objects antialiasing called "multisampling", more tedious rules.

            Point and line smoothing is widely supported, but unfortunately polygon smoothing is not available on all platforms. Even when GL_POLYGON_SMOOTH is available, it is not as convenient a means of having your whole scene antialiased as you might think. Because it is based on the blending operation, you would need to sort all your primitives from front to back! Yuck.


            Multisample(抽樣):
            A more recent addition to OpenGL to address this shortcoming is multisampling. When this feature is supported (it is an OpenGL 1.3 feature), an additional buffer is added to the framebuffer that includes the color, depth, and stencil values. All primitives are sampled multiple times per pixel, and the results are stored in this buffer.

            First: you must obtain a rendering context that has support for a multisampled framebuffer.
            setFormat(QGLFormat(QGL::DoubleBuffer | QGL::DepthBuffer | QGL::SampleBuffers));
            Second: turn multisampling on or off:
            glEnable(GL_MULTISAMPLE); // glDisable(GL_MULTISAMPLE);

            Another important note about multisampling is that when it is enabled, the point, line, and polygon smoothing features are ignored if enabled. On a given OpenGL implementation, points and lines may look better with smoothing turned on instead of multisampling.
            實體圖形效果非常的好啊, 比使用前面的antialiasing好非常多. 而且就上面兩步搞定. 但對于點和線來說, 使用smoothing的效果卻比multisampling的效果好, 所以要看情況來定.
            posted on 2009-05-23 15:14 逛奔的蝸牛 閱讀(2490) 評論(2)  編輯 收藏 引用 所屬分類: OpenGL

            評論

            # re: OpenGL: 反鋸齒 2012-07-30 14:47 外星人
            setFormat是哪里有?是哪個庫的?  回復(fù)  更多評論
              

            # re: OpenGL: 反鋸齒 2012-07-30 14:48 外星人
            setFormat在哪個庫文件?  回復(fù)  更多評論
              

            99国内精品久久久久久久| 久久久一本精品99久久精品88| 伊人久久大香线蕉影院95| 久久久噜噜噜久久| 久久天天躁狠狠躁夜夜网站| 国产精品99久久久久久宅男| 久久精品免费一区二区| 欧美一区二区精品久久| 中文字幕久久波多野结衣av| 久久99国产一区二区三区| 青青草原精品99久久精品66| 欧美大战日韩91综合一区婷婷久久青草| 久久丫精品国产亚洲av| 久久精品国产欧美日韩99热| 国产高潮国产高潮久久久91 | 99精品久久久久中文字幕| 久久综合视频网站| 亚洲国产成人久久精品影视| 亚洲国产精品18久久久久久| 久久久久九九精品影院| 久久狠狠色狠狠色综合| 亚洲精品无码久久久久久| 久久人人爽人人精品视频| 亚洲嫩草影院久久精品| 精品久久久久久成人AV| 综合久久国产九一剧情麻豆| 久久国产亚洲精品| 国产精品乱码久久久久久软件| 九九热久久免费视频| 女人香蕉久久**毛片精品| .精品久久久麻豆国产精品| 奇米综合四色77777久久| 久久综合精品国产二区无码| 少妇高潮惨叫久久久久久| 中文字幕日本人妻久久久免费| 亚洲va久久久久| 伊人久久综合成人网| 亚洲乱码中文字幕久久孕妇黑人 | 久久香蕉综合色一综合色88| 99久久久国产精品免费无卡顿| 欧美va久久久噜噜噜久久|