日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

WPF 自定义 ImageButton

發布時間:2024/8/22 编程问答 39 如意码农
生活随笔 收集整理的這篇文章主要介紹了 WPF 自定义 ImageButton 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

控件源碼:

public class ImageButton : Button
    {
        public ImageButton() {
        }

public string NoramlImgPath
        {
            get { return (string)GetValue(NoramlImgPathProperty); }
            set { SetValue(NoramlImgPathProperty, value); }
        }

public string HoverImgPath
        {
            get { return (string)GetValue(HoverImgPathProperty); }
            set { SetValue(HoverImgPathProperty, value); }
        }

public string DisableImgPath
        {
            get { return (string)GetValue(DisableImgPathProperty); }
            set { SetValue(DisableImgPathProperty, value); }
        }

public static readonly DependencyProperty NoramlImgPathProperty =
    DependencyProperty.Register(
    "NoramlImgPath",
    typeof(string),
    typeof(ImageButton),
    new PropertyMetadata(""));

public static readonly DependencyProperty HoverImgPathProperty =
    DependencyProperty.Register(
    "HoverImgPath",
    typeof(string),
    typeof(ImageButton),
    new PropertyMetadata(""));

public static readonly DependencyProperty DisableImgPathProperty =
    DependencyProperty.Register(
    "DisableImgPath",
    typeof(string),
    typeof(ImageButton),
    new PropertyMetadata(""));
    }

Style:資源文件里需要引用控件Namespace

xmlns:local="clr-namespace:Shared.Controls;assembly=Shared"
<SolidColorBrush x:Key="MouseOverBorderBrush" Color="#2D2F3D" />
<SolidColorBrush x:Key="buttonDisableBackground" Color="#222732"/>

<Style x:Key="imageButtonStyle" TargetType="local:ImageButton">
        <Setter Property="BorderThickness" Value="1"/>
        <Setter Property="BorderBrush" Value="Transparent"/>
        <Setter Property="Template" >
            <Setter.Value>
                <ControlTemplate  TargetType="{x:Type local:ImageButton}">
                    <Border x:Name="border" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}"  Width="{TemplateBinding Width}" Height="{TemplateBinding Height}"    SnapsToDevicePixels="True">
                        <Rectangle x:Name="bgrect" Margin="2">
                            <Rectangle.Fill>
                                <ImageBrush ImageSource="{Binding NoramlImgPath, RelativeSource={RelativeSource TemplatedParent}}" Stretch="Uniform" />
                            </Rectangle.Fill>
                        </Rectangle>
                    </Border>
                    <ControlTemplate.Triggers>
                        <Trigger Property="IsMouseOver" Value="True">
                            <Setter Property="Background" TargetName="border" Value="#000000"/>
                            <Setter Property="BorderBrush" TargetName="border" Value="{StaticResource MouseOverBorderBrush}"/>
                            <Setter Property="BorderThickness" TargetName="border" Value="1"/>
                            <Setter Property="Margin" TargetName="border" Value="-1"/>
                            <Setter TargetName="bgrect" Property="Fill">
                                <Setter.Value>
                                    <ImageBrush ImageSource="{Binding HoverImgPath, RelativeSource={RelativeSource TemplatedParent}}" Stretch="Uniform"  />
                                </Setter.Value>
                            </Setter>
                        </Trigger>
                        <Trigger Property="IsPressed" Value="True">
                            <Setter Property="Background" TargetName="border" Value="#000000"/>
                            <Setter Property="BorderBrush" TargetName="border" Value="{StaticResource MouseOverBorderBrush}"/>
                            <Setter Property="BorderThickness" TargetName="border" Value="1"/>
                            <Setter Property="Margin" TargetName="border" Value="1 1 -1 -1"/>
                            <Setter TargetName="bgrect" Property="Fill">
                                <Setter.Value>
                                    <ImageBrush ImageSource="{Binding HoverImgPath, RelativeSource={RelativeSource TemplatedParent}}" Stretch="Uniform"  />
                                </Setter.Value>
                            </Setter>
                        </Trigger>
                        <Trigger Property="IsEnabled" Value="False">
                            <Setter Property="Background" TargetName="border" Value="{StaticResource buttonDisableBackground}"/>
                            <Setter TargetName="bgrect" Property="Fill">
                                <Setter.Value>
                                    <ImageBrush ImageSource="{Binding DisableImgPath, RelativeSource={RelativeSource TemplatedParent}}" Stretch="Uniform"  />
                                </Setter.Value>
                            </Setter>
                        </Trigger>
                    </ControlTemplate.Triggers>
                </ControlTemplate>
            </Setter.Value>
        </Setter>
    </Style>

使用:

xmlns:shared="clr-namespace:Shared.Controls;assembly=Shared"

<shared:ImageButton   Width="24"  Height="24"  Margin="0 5" Command="{Binding SaveImageCommand}"
                                               NoramlImgPath="../Images/export_image.png"
                                               HoverImgPath="../Images/export_image_hover.png"  
                                               Style="{StaticResource imageButtonStyle}" ></shared:ImageButton>

顯示:

政常:鼠標放上:點擊:

總結

以上是生活随笔為你收集整理的WPF 自定义 ImageButton的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 夜夜夜爽 | 免费在线一区二区三区 | 久久久123 | 天天爱天天舔 | 久久国产精品亚洲 | 在线免费观看一区二区 | 偷拍女澡堂一区二区三区 | 色多多在线观看 | 国产精品免费一区 | 国产精品5 | 半推半就一ⅹ99av | 国产伦精品一区二区三区高清 | 黄色www| 欧美一区二区三区在线观看视频 | 亚洲国产欧美一区 | 成人免费大片黄在线播放 | 中日韩毛片 | 欧美精品久久久久久久久 | 99热偷拍| 自宅警备员在线观看 | 国产精品久久无码一三区 | 欧美老熟妇乱大交xxxxx | 久久久人人人 | 国产xxxxxxxxx| 小早川怜子久久精品中文字幕 | 天天噜日日噜 | 双性人做受视频 | 欧美理论片在线观看 | 嫩草影院懂你的影院 | 国产又黄又大又粗视频 | 99久久久无码国产精品性青椒 | h网站在线看| 亚州av在线 | 精品人妻码一区二区三区红楼视频 | 色婷婷久久久亚洲一区二区三区 | 噼里啪啦国语版在线观看 | 99热在线观看免费 | 懂色av蜜臀av粉嫩av分 | 99久久伊人 | 国产精品久久久久久99 | 91操人 | 这里只有精品6 | 久久大陆 | 中文av字幕 | 国产嫩草在线观看 | 国产美女无遮挡免费 | 亚洲天堂精品视频 | 免费黄色a级片 | 成人tv | 欧美日韩国产片 | 国产chinesehd天美传媒 | 亚洲自拍网站 | 欧美一区二区三区免费在线观看 | 国产日韩精品一区二区 | 欧美日韩精品网站 | 国产伦精品一区二区三区 | 国产午夜大片 | 欧美一区二区三区不卡视频 | 欧美激情黑白配 | 国产男女视频在线观看 | 日本少妇喷水 | 成年人免费观看网站 | 中文字幕在线观看精品 | a∨色狠狠一区二区三区 | 97久久人国产精品婷婷 | 婷婷人体| 精品乱码一区二区三区 | 国产福利精品在线 | 久久首页| 成人六区| 手机在线看片你懂的 | 72pao成人国产永久免费视频 | 亚洲人性生活视频 | 午夜视频在线播放 | 男人的天堂色偷偷 | 推特裸体gay猛交gay | 黄色小视屏| 免费观看h片 | 国产无码日韩精品 | 艳妇臀荡乳欲伦交换在线播放 | 国产精品va无码一区二区三区 | 国产经典一区二区 | 黄片毛片在线 | 国产一二三在线视频 | 97香蕉超级碰碰久久免费软件 | 亚洲经典视频 | 色久视频 | 精品国产日本 | 男男做爰猛烈啪啪高 | 国产精品99久久久久久久久 | 嫩草在线播放 | 九九热在线精品视频 | 天天插天天爱 | 国产精品视频一区二区三 | 天码人妻一区二区三区在线看 | 91玉足脚交嫩脚丫在线播放 | 精品人妻久久久久一区二区三区 | 国产爽视频| 欧美高清在线 |