2017-10-12 109 views
0

我如何添加多邊形的ControlTemplateControlTemplate to button 我如何能做到這一點,但在代碼:控件模板WPF

<Button x:Name="btnNew" Content="click me" HorizontalAlignment="Left" Margin="54,10,0,0" VerticalAlignment="Top" Width="250" Height="250" BorderThickness="0" UseLayoutRounding="True" > 


     <Button.Template> 
      <ControlTemplate> 
       <Polygon x:Name="poly" Points="0,50 200,20 230,150 20,200"> 
        <Polygon.Fill> 
         <ImageBrush x:Name="imgtem" Stretch="Fill" ImageSource="Images/67.png"> 
         </ImageBrush> 
        </Polygon.Fill> 
       </Polygon> 
      </ControlTemplate> 
     </Button.Template> 
    </Button> 
+0

的[定義WPF的ControlTemplate在運行時(可能的複製https://stackoverflow.com/questions/732736/define-a-wpf-controltemplate-at-runtime ) – ASh

回答

1

您可以使用XamlReader.Parse創建的的ControlTemplate,然後簡單地設置屬性Button

string xaml = "<ControlTemplate xmlns=\"http://schemas.microsoft.com/winfx/2006/xaml/presentation\" xmlns:x=\"http://schemas.microsoft.com/winfx/2006/xaml\"><Polygon x:Name=\"poly\" Points=\"0,50 200,20 230,150 20,200\"><Polygon.Fill><ImageBrush x:Name=\"imgtem\" Stretch=\"Fill\" ImageSource=\"Images/67.png\"></ImageBrush></Polygon.Fill></Polygon></ControlTemplate>"; 
ControlTemplate template = System.Windows.Markup.XamlReader.Parse(xaml) as ControlTemplate; 

Button button = new Button(); 
button.Name = "btnNew"; 
button.Content = "Click me"; 
button.HorizontalAlignment = HorizontalAlignment.Left; 
button.Margin = new Thickness(54, 10, 0, 0); 
//... 
button.Template = template;