• <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 | 阿賢
            呵呵, 這樣做界面很好玩  回復  更多評論
              
            国产精品激情综合久久| 亚洲国产另类久久久精品黑人| 国产日产久久高清欧美一区| 久久免费精品视频| 久久午夜综合久久| 久久国产精品-久久精品| 久久国产精品免费一区| 午夜精品久久久久久久| 成人a毛片久久免费播放| 亚洲天堂久久久| 国产精品久久久久久久久久免费| 亚洲国产精品嫩草影院久久| 狠狠色丁香久久综合五月| 久久久久成人精品无码 | 久久www免费人成看国产片| 亚洲精品高清一二区久久| 国产三级久久久精品麻豆三级| 中文字幕亚洲综合久久| 久久天天躁狠狠躁夜夜躁2O2O| 久久久久久无码国产精品中文字幕| 色妞色综合久久夜夜| 一级做a爰片久久毛片毛片| 免费精品99久久国产综合精品| 国产成人精品久久| 亚洲欧洲精品成人久久曰影片 | 人妻少妇精品久久| 婷婷综合久久狠狠色99h| 久久精品国产亚洲77777| 无码人妻久久一区二区三区蜜桃 | 狠狠色噜噜色狠狠狠综合久久| 欧美国产成人久久精品| 99久久亚洲综合精品成人| 青青国产成人久久91网| 国内精品伊人久久久久| 国产精品久久久久久福利漫画| 热re99久久精品国99热| 久久精品国产亚洲av麻豆色欲| 99久久精品午夜一区二区| 欧美精品一本久久男人的天堂| 久久国产精品一区二区| 99久久婷婷国产综合精品草原|