• <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 | 阿賢
            呵呵, 這樣做界面很好玩  回復  更多評論
              
            久久这里的只有是精品23| 久久人与动人物a级毛片| 亚洲综合久久夜AV | 伊人热人久久中文字幕| 久久精品中文无码资源站| 久久亚洲欧洲国产综合| 国产99久久久久久免费看| 久久精品国产99国产精偷| 国产午夜久久影院| 久久国产精品99精品国产987| 97久久香蕉国产线看观看| 久久天天躁狠狠躁夜夜96流白浆| 久久综合九色综合网站| 久久无码高潮喷水| 亚洲va久久久噜噜噜久久天堂| 亚洲精品乱码久久久久久中文字幕 | 亚洲精品99久久久久中文字幕| 久久久WWW成人免费毛片| 久久久这里有精品中文字幕| 人妻无码久久精品| 日韩久久无码免费毛片软件| 久久午夜免费视频| 伊人久久久AV老熟妇色| 国内精品久久久久久99| 欧美伊香蕉久久综合类网站| 人妻无码精品久久亚瑟影视| 亚洲中文字幕久久精品无码APP | 伊人久久五月天| 精品久久久久香蕉网| 精品久久8x国产免费观看| 91性高湖久久久久| 亚洲七七久久精品中文国产 | 久久综合噜噜激激的五月天| 欧美亚洲另类久久综合| 久久久久亚洲av综合波多野结衣 | 久久精品国产99国产精品亚洲 | 青青草国产精品久久久久| 一级A毛片免费观看久久精品| 久久国产免费观看精品3| 久久精品国产国产精品四凭| 99久久99久久精品免费看蜜桃 |