这是我到目前为止有:
<Image Source="{Binding ImageSource"} />
<Button Content"Text" ImageSource="path/image.png" />
我知道自己是不是在这里。 我想我不能看到ImageSource的定义在哪里。
我有几个这些按钮的,只是想为每一个独特的形象。 我有我使用一个按钮模板,并将其文本的伟大工程。
<Label Content="TemplateBinding Content" />
感谢你的帮助!
在你的情况下,它可以很容易的!
图像作为资源添加到您的项目,然后在XAML中使用类似如下:
<Button HorizontalAlignment="Left" Margin="20,0,0,20" VerticalAlignment="Bottom" Width="50" Height="25">
<Image Source="image.png" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Margin="0">
</Image>
</Button>
或者,更复杂的方式:
如果您使用的MVVM模式,你可以做以下
在您的XAML:
<Button Focusable="False" Command="{Binding CmdClick}" Margin="0">
<Image Source="{Binding ButtonImage}" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Margin="0">
</Image>
</Button>
在您的视图模型:
private Image buttonImage;
public Image ButtonImage
{
get
{
return buttonImage;
}
}
而在某处你的视图模型或它的初始化的构造函数:
BitmapImage src = new BitmapImage();
src.BeginInit();
src.UriSource = new Uri("image.png", UriKind.Relative);
src.CacheOption = BitmapCacheOption.OnLoad;
src.EndInit();
buttonImage = new Image();
buttonImage.Source = src;
在您的XAML:
<Button Focusable="False" Command="{Binding CmdClick}" Margin="0">
<Image Source="{Binding ImageSource,UpdateSourceTrigger=PropertyChanged} HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Margin="0">
</Image>
</Button>
在您的视图模型:
private BitmapImage _ImageSource;
public BitmapImage ImageSource
{
get { return this._ImageSource; }
set { this._ImageSource = value; this.OnPropertyChanged("ImageSource"); }
}
private void OnPropertyChanged(string v)
{
// throw new NotImplementedException();
if (PropertyChanged != null)
PropertyChanged(this, new PropertyChangedEventArgs(v));
}
public event PropertyChangedEventHandler PropertyChanged;
而在某处你的视图模型或它的初始化的构造函数:
string str = System.Environment.CurrentDirectory;
string imagePath = str + "\\Images\\something.png";
this.ImageSource = new BitmapImage(new Uri(imagePath, UriKind.Absolute));
要么:
string imagePath = "\\Images\\something.png";
this.ImageSource = new BitmapImage(new Uri(imagePath, UriKind.Relative));