• <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 | 阿賢
            呵呵, 這樣做界面很好玩  回復  更多評論
              
            久久中文精品无码中文字幕| 中文精品久久久久国产网址| 亚洲人AV永久一区二区三区久久 | 亚洲精品蜜桃久久久久久| 亚洲人成无码久久电影网站| 亚洲午夜无码久久久久| 久久夜色精品国产亚洲| 伊人久久大香线蕉综合热线| 日韩AV无码久久一区二区 | 久久久久久狠狠丁香| 韩国三级中文字幕hd久久精品| 久久无码国产专区精品| 伊人久久免费视频| 久久天天躁狠狠躁夜夜96流白浆| 久久久久国产精品三级网| 国产精品毛片久久久久久久| 国产99久久久国产精品小说| 久久精品亚洲乱码伦伦中文| 久久精品国产免费| 欧美va久久久噜噜噜久久| 久久本道综合久久伊人| 91精品国产高清91久久久久久| 亚洲精品无码久久毛片| 精品久久久久一区二区三区| 99精品久久精品| 国产91色综合久久免费| 久久精品国产亚洲AV麻豆网站| 欧美黑人激情性久久| 亚洲国产综合久久天堂| 久久久午夜精品福利内容| 久久精品国产亚洲Aⅴ香蕉| 国产成人精品久久| 久久国产午夜精品一区二区三区| 无码乱码观看精品久久| 久久国产福利免费| 国产精品美女久久久久AV福利| 国产成人精品久久免费动漫| 久久精品中文騷妇女内射| a级成人毛片久久| 欧美日韩中文字幕久久伊人| 一级做a爰片久久毛片16|