• <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>

            AGG入門(四) - 渲染緩存和混合器

            一、上一節(jié)的代碼

                    agg::rendering_buffer &rbuf = rbuf_window();
                    agg::pixfmt_rgb24 pixf(rbuf);

                    agg::renderer_base<agg::pixfmt_rgb24> renb(pixf);
                    renb.clear(agg::rgba8(255, 255, 255));

                    pixf.copy_pixel(20, 20, agg::rgba8(0, 0, 255));

            二、渲染緩存

            渲染緩存保存著一個(gè)個(gè)像素,作為AGG的畫布。它僅僅是一個(gè)內(nèi)存塊,用來儲存像素信息,不提供任何繪圖功能,只允許你讀取和修改里面的數(shù)據(jù)。它也不告訴你里面的像素是灰度的、RGB的還是RGBA的,不告訴你從哪里到哪里是一個(gè)像素——它只是用來管理內(nèi)存數(shù)據(jù)的。

            頭文件

            #include "platform/agg_platform_support.h"

            類型定義

            typedef row_accessor<int8u> rendering_buffer //int8u是8 bit無符號整形

            基本成員函數(shù)

            • rendering_buffer(int8u* buf, unsigned width, unsigned height, int stride) 
                      構(gòu)造函數(shù),指定事先分配好的內(nèi)存塊(到時(shí)就畫到上面)首地址、寬高、一行的字節(jié)數(shù)(默認(rèn)全部都是0);
            • row_ptr(int y)
                      返回第y行的首地址;
            • copy_from(void *buf)
                      從buf中拷貝像素;
            • clear(int8u value)
                      用value清空緩存
            • buf(), height(), weight(), stride()
                      返回緩存首地址、寬高、一行的字節(jié)數(shù);
            注:代碼中的rbuf_window()是platform_support的一個(gè)成員函數(shù),用于返回platform_support一開始幫你申請的緩存引用。

            三、混合器

            混合器的存在是為了適應(yīng)不同平臺、不同需求下的不同像素格式。混合器有三種:agg::rgba,agg::rgba8agg::rgba16,都是用來指定顏色的,rgba每個(gè)通道儲存為double,rgba8為unsigned char,rgba16為int或long int;混合器起到的作用就像Win32API里的RGB和COLORREF宏。

            頭文件

            #include "agg_pixfmt_rgba.h"

            類型定義

            struct rgba8; //對,你沒有看錯(cuò),是結(jié)構(gòu),不是類……

            基本成員函數(shù)

            • rgba8(unsigned r, unsigned g, unsigned b, unsigned a)
                      無須解釋了吧,最大255;
            • clear(), no_color()
                      四個(gè)通道全部清零,也就是變沒色咯;
            • transparent()
                      alpha清零,變透明;
            • opacity()
                      返回透明度,用double表示;
            • gradient(agg::rgba8 &c, double k)
                      顏色梯度,就是顏色變?yōu)閺脑鹊念伾珴u變?yōu)閏,變化率為k;
            • add(agg::rgba8 &c, unsinged cover)
                      顏色疊加,疊加一個(gè)透明度為cover/255的顏色c;

            成員變量

            • r, g, b, a都是無符號整型;

            四、像素格式混合器


            像素格式混合器的作用是直接操作像素(也就是緩存里保存的數(shù)據(jù),但起碼有個(gè)像素的樣子),起到Win32API里的SetPixel()和GetPixel()的作用。像素格式由兩個(gè)屬性決定:混合器類型【agg::rgba8/agg::rgba16】、bgr/rgb/rgba/abgr順序【agg::order_bgr/agg::order_rgb/agg::order_rgba/agg::order_abgr】——這樣,共8種像素格式,它們起名字的規(guī)則就是:
            agg::pixfmt_[order][bits*3];
            下面用最常用的agg::pixfmt_rgb24來解釋:

            頭文件

            #include "agg_pixfmt_rgb.h"

            類型定義

            typedef pixfmt_alpha_blend_rgb<blender_rgb<rgba8,  order_rgb>, rendering_buffer> pixfmt_rgb24;

            基本成員函數(shù)

            • pixfmt_rgb24(agg::rendering_buffer &) 
                      構(gòu)造函數(shù),指定緩存就好;
            • blend_pixel(agg::rgba8& c, int x, int y, int8u cover)
                      用顏色c以cover(覆蓋率=透明度)的透明度混合像素(x, y);
            • copy_pixel(agg::rgba8& c, int x, int y),pixel(int x, int y)
                      這個(gè)就是相當(dāng)于SetPixel()和GetPixel()了;
            • copy_hline(int x, int y, unsigned len, agg::rgba8& c)
              copy_vline(int x, int y, unsigned len, agg::rgba8& c)  
                      從(x, y)開始打橫(豎)順序設(shè)置len長度的像素;
            • blend_hline(int x, int y, unsigned len, agg::rgba8& c, int8u cover)
              blend_vline(int x, int y, unsigned len, agg::rgba8& c, int8u cover) 
                      從(x, y)開始打橫(豎)順序混合len長度的像素;
            • copy_solid_hspan(int x, int y, unsigned len, agg::rgba8* colors)
              copy_solid_vspan(int x, int y, unsigned len, agg::rgba8* colors)
              blend_solid_hspan(int x, int y, unsigned len, agg::rgba8* colors, int8u* cover, int8u cover)
              blend_solid_vspan(int x, int y, unsigned len, agg::rgba8* colors, int8u* cover, int8u cover)
                      同上兩個(gè),不過不是一個(gè)顏色,是一系列的顏色;
            • for_each_pixel(void (*f)(agg::rgba8* color))
                      每一像素執(zhí)行一遍f;
            • copy_from(agg::rendering_buffer & from, int xdst, int ydst, int xsrc, int ysrc, unsigned len)
              blend_from(agg::rendering_buffer & from, int xdst, int ydst, int xsrc, int ysrc, unsigned len[, unsigned cover])  
                      從緩存form中(xsrc, ysrc)順序復(fù)制(混合)到當(dāng)前緩存的(xdst, ydst)中;
            【其他函數(shù)和像素格式就要靠大家的舉一反三,觸類旁通了……】

            五、結(jié)語

            上面說的三者關(guān)系是:混合器混合RGBA四個(gè)通道,像素格式混合器混合像素,像素格式混合器操作的結(jié)果是使渲染緩存里的數(shù)據(jù)發(fā)生變化,而混合器則不會,因?yàn)樗淖饔脙H僅是表示顏色。

            posted on 2012-07-24 16:29 Shihira 閱讀(4228) 評論(0)  編輯 收藏 引用 所屬分類: 圖形編程

            導(dǎo)航

            統(tǒng)計(jì)

            公告

            留言簿(2)

            隨筆分類

            搜索

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            久久青青草原精品国产软件 | 久久国产亚洲精品| 亚洲国产成人精品91久久久 | 久久九色综合九色99伊人| 色播久久人人爽人人爽人人片aV| 热99RE久久精品这里都是精品免费| 伊人久久精品无码av一区| 国产一级做a爰片久久毛片| 久久精品人妻一区二区三区| 日产精品久久久久久久性色 | 中文字幕久久波多野结衣av| 久久精品国产免费| 色欲综合久久躁天天躁蜜桃| 久久丝袜精品中文字幕| 韩国三级大全久久网站| 亚洲人成伊人成综合网久久久| 91秦先生久久久久久久| 国产午夜精品久久久久免费视| 精品久久久久久久国产潘金莲 | AV狠狠色丁香婷婷综合久久 | 久久夜色tv网站| 久久精品中文无码资源站| 久久亚洲精品无码aⅴ大香| 精品久久久久久无码免费| 久久天堂电影网| 99久久婷婷免费国产综合精品| 色欲久久久天天天综合网精品| 久久久久久久97| 人妻无码久久一区二区三区免费| 国产精品美女久久福利网站| 性高湖久久久久久久久AAAAA| 亚洲?V乱码久久精品蜜桃| 久久99九九国产免费看小说| 亚洲国产成人精品久久久国产成人一区二区三区综 | 久久久久久久波多野结衣高潮| 久久这里只精品99re66| 久久久久久伊人高潮影院| 亚洲国产精品久久电影欧美| 无码伊人66久久大杳蕉网站谷歌| 亚洲成色www久久网站夜月| 看久久久久久a级毛片|