• <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) 閱讀(3541) 評論(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久久成人免费播放| 精品久久久久久久久午夜福利| 精品免费久久久久久久| 国产AV影片久久久久久| 亚洲国产视频久久| 精品久久久久久| 亚洲狠狠婷婷综合久久蜜芽| 久久久精品午夜免费不卡| 99久久做夜夜爱天天做精品| 久久久久久久99精品免费观看| 久久无码精品一区二区三区| 久久99精品久久久久婷婷| 色99久久久久高潮综合影院 | 精品无码久久久久久久动漫| 77777亚洲午夜久久多人| 91久久福利国产成人精品| 亚洲va久久久噜噜噜久久狠狠| 久久精品国产精品亚洲| 久久精品国产清高在天天线| 久久精品国产色蜜蜜麻豆| 国产精品伊人久久伊人电影| 久久久精品2019免费观看| 2021国产精品午夜久久| 久久久久久极精品久久久| 久久99国产精品久久99| 久久精品中文无码资源站| 国产激情久久久久久熟女老人| 亚洲国产成人精品无码久久久久久综合| 久久精品国产亚洲av水果派| 久久精品国产亚洲AV不卡| 精品国产日韩久久亚洲 | 久久av无码专区亚洲av桃花岛| 亚洲人成网站999久久久综合| 国产精品嫩草影院久久| A级毛片无码久久精品免费| 国产精品久久久久久久| 2021久久国自产拍精品| 久久99国产综合精品女同| 久久精品人人做人人爽97 | 久久九九免费高清视频|