• <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>

            08年05月08日

            Posted on 2008-05-08 16:30 RichardHe 閱讀(1935) 評論(4)  編輯 收藏 引用
            CEGUI有背景圖片的BUTTON:
            昨天聽到刀哥問我對Looknfeel寫東西有沒有什么心德體會.說實話,我還真正的寫過一個wideget.然后突然就有一個沖動想法.很多東西不寫是不會熟悉的.我就參考刀哥的方法寫了一個BUTTON
            有兩種方法可以實現,一為在Looknfeel文件中直接修改
            <WidgetLook name="Vanilla/MyButton">
                    
            <PropertyDefinition name="NormalTextColour" initialValue="FFFFFFFF" redrawOnWrite="true" />
                    
            <PropertyDefinition name="HoverTextColour" initialValue="FFFFFFFF" redrawOnWrite="true" />
                    
            <PropertyDefinition name="PushedTextColour" initialValue="FFFFFFFF" redrawOnWrite="true" />
                    
            <PropertyDefinition name="DisabledTextColour" initialValue="FF888888" redrawOnWrite="true" />
                    
            <PropertyDefinition name="VertLabelFormatting" initialValue="CentreAligned" />
                    
            <PropertyDefinition name="HorzLabelFormatting" initialValue="CentreAligned" />
                    
            <PropertyDefinition name="NormalImage" initialValue="" redrawOnWrite="true" />
                    
            <PropertyDefinition name="HoverImage" initialValue="" redrawOnWrite="true" />
                    
            <PropertyDefinition name="PushedImage" initialValue="" redrawOnWrite="true" />
                    
            <PropertyDefinition name="DisabledImage" initialValue="" redrawOnWrite="true" />
                    
            <PropertyDefinition name="VertImageFormatting" initialValue="Stretched" redrawOnWrite="true" />
                    
            <PropertyDefinition name="HorzImageFormatting" initialValue="Stretched" redrawOnWrite="true" />
                    
            <ImagerySection name="label">
                        
            <TextComponent>
                            
            <Area>
                                
            <Dim type="LeftEdge"><AbsoluteDim value="0" /></Dim>
                                
            <Dim type="TopEdge"><AbsoluteDim value="0" /></Dim>
                                
            <Dim type="Width"><UnifiedDim scale="1" type="Width" /></Dim>
                                
            <Dim type="Height"><UnifiedDim scale="1" type="Height" /></Dim>
                            
            </Area>
                            
            <VertFormatProperty name="VertLabelFormatting" />
                            
            <HorzFormatProperty name="HorzLabelFormatting" />
                        
            </TextComponent>
                    
            </ImagerySection>
                    
            <ImagerySection name="normal">
                            
            <FrameComponent>
                            
            <Area>
                                
            <Dim type="LeftEdge"><AbsoluteDim value="0" /></Dim>
                                
            <Dim type="TopEdge"><AbsoluteDim value="0" /></Dim>
                                
            <Dim type="Width"><UnifiedDim scale="1" type="Width" /></Dim>
                                
            <Dim type="Height"><UnifiedDim scale="1" type="Height" /></Dim>
                            
            </Area>
                            
            <Image type="LeftEdge" imageset="TaharezLook" image="ButtonLeftNormal" />
                            
            <Image type="RightEdge" imageset="TaharezLook" image="ButtonRightNormal" />
                            
            <Image type="Background" imageset="TaharezLook" image="ButtonMiddleNormal" />
                        
            </FrameComponent>
                        
            <ImageryComponent>
                            
            <Area>
                                
            <Dim type="LeftEdge" ><AbsoluteDim value="0" /></Dim>
                                
            <Dim type="TopEdge" ><AbsoluteDim value="0" /></Dim>
                                
            <Dim type="Width" ><UnifiedDim scale="1" type="Width" /></Dim>
                                
            <Dim type="Height" ><UnifiedDim scale="1" type="Height" /></Dim>
                            
            </Area>
                            
            <ImageProperty name="NormalImage" />
                            
            <VertFormatProperty name="VertImageFormatting" />
                            
            <HorzFormatProperty name="HorzImageFormatting" />
                        
            </ImageryComponent>
                    
            </ImagerySection>
                    
            <ImagerySection name="hover">
                        
            <FrameComponent>
                            
            <Area>
                                
            <Dim type="LeftEdge" ><AbsoluteDim value="0" /></Dim>
                                
            <Dim type="TopEdge" ><AbsoluteDim value="0" /></Dim>
                                
            <Dim type="Width" ><UnifiedDim scale="1" type="Width" /></Dim>
                                
            <Dim type="Height" ><UnifiedDim scale="1" type="Height" /></Dim>
                            
            </Area>
                            
            <Image type="LeftEdge" imageset="TaharezLook" image="ButtonLeftHighlight" />
                            
            <Image type="RightEdge" imageset="TaharezLook" image="ButtonRightHighlight" />
                            
            <Image type="Background" imageset="TaharezLook" image="ButtonMiddleHighlight" />
                        
            </FrameComponent>
                     
                        
            <ImageryComponent>
                            
            <Area>
                                
            <Dim type="LeftEdge" ><AbsoluteDim value="0" /></Dim>
                                
            <Dim type="TopEdge" ><AbsoluteDim value="0" /></Dim>
                                
            <Dim type="Width" ><UnifiedDim scale="1" type="Width" /></Dim>
                                
            <Dim type="Height" ><UnifiedDim scale="1" type="Height" /></Dim>
                            
            </Area>
                            
            <ImageProperty name="HoverImage" />
                            
            <VertFormatProperty name="VertImageFormatting" />
                            
            <HorzFormatProperty name="HorzImageFormatting" />
                        
            </ImageryComponent>
                    
            </ImagerySection>
                    
            <ImagerySection name="pushed">
                          
            <FrameComponent>
                            
            <Area>
                                
            <Dim type="LeftEdge" ><AbsoluteDim value="0" /></Dim>
                                
            <Dim type="TopEdge" ><AbsoluteDim value="0" /></Dim>
                                
            <Dim type="Width" ><UnifiedDim scale="1" type="Width" /></Dim>
                                
            <Dim type="Height" ><UnifiedDim scale="1" type="Height" /></Dim>
                            
            </Area>
                            
            <Image type="LeftEdge" imageset="TaharezLook" image="ButtonLeftPushed" />
                            
            <Image type="RightEdge" imageset="TaharezLook" image="ButtonRightPushed" />
                            
            <Image type="Background" imageset="TaharezLook" image="ButtonMiddlePushed" />
                        
            </FrameComponent>
                        
                        
            <ImageryComponent>
                            
            <Area>
                                
            <Dim type="LeftEdge" ><AbsoluteDim value="0" /></Dim>
                                
            <Dim type="TopEdge" ><AbsoluteDim value="0" /></Dim>
                                
            <Dim type="Width" ><UnifiedDim scale="1" type="Width" /></Dim>
                                
            <Dim type="Height" ><UnifiedDim scale="1" type="Height" /></Dim>
                            
            </Area>
                            
            <ImageProperty name="PushedImage" />
                            
            <VertFormatProperty name="VertImageFormatting" />
                            
            <HorzFormatProperty name="HorzImageFormatting" />
                        
            </ImageryComponent>
                    
            </ImagerySection>
                    
            <StateImagery name="Normal">
                        
            <Layer>
                            
            <Section section="normal" />
                            
            <Section section="label">
                                
            <ColourProperty name="NormalTextColour" />
                            
            </Section>
                        
            </Layer>
                    
            </StateImagery>
                    
            <StateImagery name="Hover">
                        
            <Layer>
                            
            <Section section="hover" />
                            
            <Section section="label">
                                
            <ColourProperty name="HoverTextColour" />
                            
            </Section>
                        
            </Layer>
                    
            </StateImagery>
                    
            <StateImagery name="Pushed">
                        
            <Layer>
                            
            <Section section="pushed" />
                            
            <Section section="label">
                                
            <ColourProperty name="PushedTextColour" />
                            
            </Section>
                        
            </Layer>
                    
            </StateImagery>
                    
            <StateImagery name="PushedOff">
                        
            <Layer>
                            
            <Section section="hover" />
                            
            <Section section="label">
                                
            <ColourProperty name="HoverTextColour" />
                            
            </Section>
                        
            </Layer>
                    
            </StateImagery>
                    
            <StateImagery name="Disabled">
                        
            <Layer>
                            
            <Section section="normal">
                                
            <Colours topLeft="FF7F7F7F" topRight="FF7F7F7F" bottomLeft="FF7F7F7F" bottomRight="FF7F7F7F" />
                            
            </Section>
                            
            <Section section="label">
                                
            <ColourProperty name="DisabledTextColour" />
                            
            </Section>
                        
            </Layer>
                    
            </StateImagery>
                
            </WidgetLook>
            <PropertyDefinition name="NormalImage" initialValue="" redrawOnWrite="true" />
            <PropertyDefinition name="HoverImage" initialValue="" redrawOnWrite="true" />        <PropertyDefinition name="PushedImage" initialValue="" redrawOnWrite="true" />
            定義三個屬性,分別為NormalImage,HoverImage,PushImage;代表三個狀態下的顯示的圖片
            如果想在上面的初始化固定圖片也是可以的initialValue="set:imagesetname image:對應里面的小圖名字"
            我的
            initialValue="set:Vanilla-Images image:ShadowBrush"


            另一個方法可以在程序中控制,這樣的話,可以針對不同的BUTTON可以設置不同的背景圖片.我的程序如下:

                WindowManager& winMgr = WindowManager::getSingleton();
                Window* button = winMgr.getWindow("root/MyButton");         //
            "root/Richard"為你的你窗口layout文件中一個BUTTON

                button->setProperty("NormalImage","set:Vanilla-Images image:ShadowBrush");

               
            1 <?xml version="1.0" encoding="UTF-8"?>
            2 
            3 <GUILayout >
            4 <Window Type="Vanilla/Richard" Name="root/MyButton" >
            5             <Property Name="Font" Value="DejaVuSans-10" />
            6             <Property Name="Text" Value="MyButton" />
            7             <Property Name="UnifiedMaxSize" Value="{{1,0},{1,0}}" />
            8             <Property Name="UnifiedAreaRect" Value="{{0.225,0},{0.433333,0},{0.474998,0},{0.556667,0}}" />
            9 </GUILayout>

              同時對應的主題文件.scheme添加一個MAP

            1 <?xml version="1.0" ?>
            2 <GUIScheme Name="VanillaSkin">
            3     <Imageset Name="Vanilla-Images" Filename="Vanilla.imageset" />
            4     <LookNFeel Filename="Vanilla.looknfeel" />
            5     <WindowRendererSet Filename="CEGUIFalagardWRBase" />
            6 <FalagardMapping WindowType="Vanilla/MyButton" TargetType="CEGUI/PushButton" Renderer="Falagard/Button" LookNFeel="Vanilla/MyButton" />
            7 </GUIScheme>

            以上東西我要十分感覺兩位游戲界新朋友的指點
            夏科藝(http://blog.csdn.net/powerkoria/)和 付坤(http://blog.csdn.net/kun1234567/)

            Feedback

            # re: 08年05月08日  回復  更多評論   

            2008-05-08 18:15 by lonkil
            CEGUI做界面,沒有一個生成工具,不累死人呀。

            # re: 08年05月08日  回復  更多評論   

            2008-05-08 19:01 by RichardHe
            @lonkil
            looknfeel肯定是要自己寫的了,不過可以參考CEGUI自帶的.
            像IMAGESET和LAYOUT都有工具的.

            # re: 08年05月08日  回復  更多評論   

            2008-05-10 00:31 by 放屁阿狗
            在做wince項目時,ui frame都是自己實現的,cegui我剛剛開始接觸,覺得其設計確實很有借鑒的作用,開始琢磨cegui

            老兄是否做過cegui到wince的移植

            # re: 08年05月08日  回復  更多評論   

            2008-05-10 09:06 by RichardHe
            @放屁阿狗
            沒有,目前也只是在WIN32上面跑下而已.
            好像可以移到WINCE上面的..有那么個宏定義就可以來用哪個編譯器來編譯

            posts - 94, comments - 138, trackbacks - 0, articles - 94

            Copyright © RichardHe

            亚洲精品tv久久久久| 久久久久久综合一区中文字幕| 国产激情久久久久久熟女老人| 欧美久久天天综合香蕉伊| 日韩欧美亚洲综合久久| 久久综合精品国产二区无码| 97久久精品无码一区二区天美| 国产精品成人99久久久久 | 国产一区二区精品久久岳| 欧美日韩精品久久久久| 久久99精品国产自在现线小黄鸭| 久久久久久久久久久免费精品| 国产精品无码久久综合| 国内精品久久久久久不卡影院| 久久国产色av免费看| 亚洲精品国精品久久99热| 久久久一本精品99久久精品88| 久久久久久精品免费看SSS| 久久久老熟女一区二区三区| 久久天天日天天操综合伊人av| 日本免费久久久久久久网站| 中文国产成人精品久久亚洲精品AⅤ无码精品| 久久人人爽人人爽人人片AV不| 久久91精品国产91久久小草| 欧美一区二区久久精品| 久久久中文字幕| 综合人妻久久一区二区精品| 久久夜色精品国产www| 久久青青草原精品影院| 日韩人妻无码精品久久久不卡| 婷婷久久综合九色综合绿巨人 | 色综合久久中文字幕综合网 | 久久综合亚洲色HEZYO国产| 国产精品久久久久天天影视| 中文国产成人精品久久不卡| 久久久久久国产a免费观看黄色大片 | 久久久久国产精品人妻| 性高朝久久久久久久久久| 久久国产成人亚洲精品影院| 国产ww久久久久久久久久| 国产99久久久久久免费看|