• <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>
            隨筆-341  評論-2670  文章-0  trackbacks-0
                這篇文章描述的一個圖形元素模板終于通過了冒煙測試。下面將展示模板的XML代碼、調用模板的代碼以及截圖。

                下面的XML描述了一個黑變藍底的長方形里面居中一個文字。
             1 <?xml version="1.0" encoding="utf-8" ?>
             2 <irconfig xmlns="http://tempuri.org/irconfig.xsd">
             3   <resources>
             4     <brush name="blue_brush" kind="solid">
             5       <main_color r="128" g="255" b="255" a="255" />
             6     </brush>
             7     <brush name="black_brush" kind="solid">
             8       <main_color r="0" g="0" b="0" a="255"/>
             9     </brush>
            10     <pen name="border_pen" brush="black_brush" endcap="round" join="round" weight="5"/>
            11     <font name="text_font" face="微軟雅黑" size="96"/>
            12   </resources>
            13   <templates>
            14     <template name="display">
            15       <properties>
            16         <property name="x" type="int" default="0"/>
            17         <property name="y" type="int" default="0"/>
            18         <property name="w" type="int" default="100"/>
            19         <property name="h" type="int" default="100"/>
            20         <property name="content" type="str" default=""/>
            21       </properties>
            22       <content>
            23         <rectangle x="$x" y="$y" width="$w" height="$h" pen="border_pen" brush="blue_brush">
            24           <text
            25             font="text_font"
            26             brush="black_brush"
            27             x="($w-this.width)/2"
            28             y="($h-this.height)/2"
            29             text="$content"
            30             />
            31         </rectangle>
            32       </content>
            33     </template>
            34   </templates>
            35 </irconfig>
            36 

                于是我們可以把模板“display”創建之后,設置x、y、w、h、content,然后顯示在一個窗口上:
             1 class ConfigForm : public VL_WinForm
             2 {
             3 protected:
             4     IVL_IrFactory::Ptr                FFactory;
             5     IVL_IrCanvas::Ptr                FCanvas;
             6     VL_IrConfigLoader::Ptr            FLoader;
             7     VL_IrConfig::Ptr                FConfig;
             8     VL_IrTemplateInstance::Ptr        FInstance;
             9 public:
            10     ConfigForm():VL_WinForm(true)
            11     {
            12         SetBorder(vwfbSingle);
            13         SetMinimizeBox(false);
            14         SetMaximizeBox(false);
            15         SetClientWidth(800);
            16         SetClientHeight(600);
            17         SetText(L"Vczh Interaction Renderer Template Test");
            18 
            19         FFactory=CreateInteractionFactory(L"GDI");
            20         FCanvas=FFactory->CreateCanvas(this);
            21         FLoader=new VL_IrConfigLoader(FFactory);
            22         FConfig=FLoader->Load(VFileName(GetApplication()->GetAppName()).MakeAbsolute(L"..\\Renderer\\IrConfig_Test.xml").GetStrW());
            23 
            24 
            25         VL_IrBrushRec WhiteBrushRec;
            26         WhiteBrushRec.BrushKind=VL_IrBrushRec::bkSolid;
            27         WhiteBrushRec.MainColor=VL_IrColor(255,255,255);
            28         IVL_IrBrush::Ptr WhiteBrush=FFactory->CreateBrush(WhiteBrushRec);
            29 
            30         IVL_IrRectangle::Ptr Root=FFactory->CreateRectangle();
            31         Root->Properties()->SetBrush(WhiteBrush);
            32         Root->Update(VL_IrPoint(0,0),VL_IrPoint(800,600));
            33         FCanvas->SetRootElement(Root);
            34 
            35         FInstance=FConfig->FindTemplate(L"display")->CreateInstance();
            36         for(VInt i=0;i<FInstance->GetRootElements().GetCount();i++)
            37         {
            38             Root->Container()->AddChild(FInstance->GetRootElements()[i]);
            39         }
            40 
            41         FInstance->GetInts()[L"x"]=100;
            42         FInstance->GetInts()[L"y"]=100;
            43         FInstance->GetInts()[L"w"]=600;
            44         FInstance->GetInts()[L"h"]=400;
            45         FInstance->GetStrs()[L"content"]=L"Template";
            46         FInstance->Update();
            47 
            48         FCanvas->Render();
            49     }
            50 };

                于是打開這個窗口,就變成了這樣:
                以后可以方便地為各種控件設計皮膚了。接下來是模板的測試,然后開始設計控件的架構。
            posted on 2009-08-19 03:29 陳梓瀚(vczh) 閱讀(3528) 評論(5)  編輯 收藏 引用 所屬分類: 2D

            評論:
            # re: C++界面庫:Graphic Element Template實現 2009-08-19 07:21 | ABC
            很強大!  回復  更多評論
              
            # re: C++界面庫:Graphic Element Template實現 2009-08-20 02:26 | 空明流轉
            很冒煙!  回復  更多評論
              
            # re: C++界面庫:Graphic Element Template實現 2009-08-21 01:21 | 羅萊家紡
            世界的粉紅色的  回復  更多評論
              
            # re: C++界面庫:Graphic Element Template實現[未登錄] 2009-08-25 07:28 | 我要去桂林
            很強大  回復  更多評論
              
            # re: C++界面庫:Graphic Element Template實現 2009-09-25 00:27 | 阿賢
            呵呵, 這樣做界面很好玩  回復  更多評論
              
            99久久精品久久久久久清纯| 久久大香香蕉国产| 国产亚州精品女人久久久久久 | 国产亚洲精品久久久久秋霞 | 污污内射久久一区二区欧美日韩 | 97久久久精品综合88久久| 91精品国产9l久久久久| 国产99久久久国产精品~~牛| 久久无码人妻精品一区二区三区| 久久91精品国产91| 99久久无码一区人妻a黑| 久久久精品国产亚洲成人满18免费网站| 无码精品久久一区二区三区 | 热久久国产精品| 久久久国产视频| 99久久久久| 精品人妻久久久久久888| 久久国产精品国语对白| 亚洲精品无码久久久久| 久久av高潮av无码av喷吹| 久久久精品2019免费观看| 久久青青草视频| 久久99精品久久久久久齐齐| 97久久国产亚洲精品超碰热| 久久久高清免费视频| 国内精品久久久久影院网站| 97久久超碰成人精品网站| 性高湖久久久久久久久| 久久只有这里有精品4| 精品久久久久久无码人妻热| 久久国产乱子伦精品免费强| 亚洲国产精品无码久久一区二区| 日本欧美国产精品第一页久久| 99久久亚洲综合精品网站| 久久精品国产亚洲AV电影| 国产亚洲美女精品久久久2020| 亚洲人成无码网站久久99热国产 | 亚洲乱码中文字幕久久孕妇黑人 | 精品一区二区久久久久久久网站| 久久精品www人人爽人人| 久久亚洲精精品中文字幕|