WPF Image UriSource и привязка данных с помощью http: URL
у меня проблема с отображением изображения с веб-URL в пользовательском элементе управления WPF. Я проработал все предложения по аналогичной проблеме, заданной на этом сайте в августе 2008 года (UriSource изображения и привязка данных), но ни одно из этих предложений уже работал.
что я хотел бы сделать, так это:
<Image Width="50" Name="MemberImage">
<Image.Source>
<BitmapImage DecodePixelWidth="50" UriSource="{Binding Member.ImageFilePathUri}" />
</Image.Source>
</Image>
ImageFilePathUri-это Uri, созданный из строкового пути через:
public Uri ImageFilePathUri
{
get
{
return new Uri(this.ImageFilePath);
}
}
}
это дает "свойство" UriSource " или свойство Необходимо задать' StreamSource'.- ошибка, как и ожидалось.
Я также попытался использовать преобразователь значений:
public class ImageConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
var image = new BitmapImage();
image.BeginInit();
if (value != null)
{
image.UriSource = new Uri((string)value);
}
image.DecodePixelWidth = 50;
image.EndInit();
return image;
}
}
однако привязка к нему с помощью:
<Image Name="TestImage" Width="50" Source="{Binding Path=Member.ImageFilePath, Converter=Parliament.HansardApplicationSuite.Logging.Helpers.ImageConverter}"></Image>
не отображает изображение.
дальнейшая попытка загрузить изображение программно, в конструкторе элемента управления и / или событие control Loaded также не сработали:
if (this.MemberRollItemViewModel.Member != null)
{
var image = new BitmapImage();
image.BeginInit();
image.UriSource = new Uri(this.MemberRollItemViewModel.Member.ImageFilePath);
image.DecodePixelWidth = 50;
image.EndInit();
this.MemberImage.Source = image;
}
единственное, что сработало, это сохранение изображения в локальный путь к файлу и отображение что:
<Image Width="50" Name="MemberImage">
<Image.Source>
<BitmapImage DecodePixelWidth="50" UriSource="C:Databc64e7b-2df5-40d5-b6c4-eaf732318222.jpg" />
</Image.Source>
</Image>
это, очевидно, полезно только при отладке проблемы и не является решением. Тот же код, но замена http-адреса для локального пути к файлу не работает.
<Image.Source>
<BitmapImage DecodePixelWidth="50" UriSource="http://member.org/6bc64e7b-2df5-40d5-b6c4-eaf732318222.jpg" />
</Image.Source>
обновление:
это реализация свойства MemberImage.
public BitmapImage MemberImage
{
get
{
var image = new BitmapImage();
if (this.Member != null)
{
WebRequest request = WebRequest.Create(new Uri(this.Member.ImageFilePath, UriKind.Absolute));
request.Timeout = -1;
WebResponse response = request.GetResponse();
Stream responseStream = response.GetResponseStream();
BinaryReader reader = new BinaryReader(responseStream);
MemoryStream memoryStream = new MemoryStream();
byte[] bytebuffer = new byte[BytesToRead];
int bytesRead = reader.Read(bytebuffer, 0, BytesToRead);
while (bytesRead > 0)
{
memoryStream.Write(bytebuffer, 0, bytesRead);
bytesRead = reader.Read(bytebuffer, 0, BytesToRead);
}
image.BeginInit();
memoryStream.Seek(0, SeekOrigin.Begin);
image.StreamSource = memoryStream;
image.EndInit();
}
return image;
}
}
обновление:
вот как я привязываюсь к элементу управления на мой взгляд:
<Image Width="50" Source="{Binding MemberImage}" />
MemberImage-это свойство, которое я дал выше. Мои данные контекст устанавливается правильно, потому что это свойство выполняется, оно просто не возвращает изображение.
1 ответов
WebURL не может быть предоставлен в качестве источника для свойства UriSource BitmapImage. Если это weburl, вам нужно загрузить этот образ локально и привязать этот путь к UriSource. Смотрите ниже
обновление:
void MainWindow_Loaded(object sender, RoutedEventArgs e)
{
var image = new BitmapImage();
int BytesToRead=100;
WebRequest request = WebRequest.Create(new Uri("http://www.interweb.in/attachments/pc-wallpapers/16187d1222942178-nature-wallpaper-nature-summer-wallpaper.jpg", UriKind.Absolute));
request.Timeout = -1;
WebResponse response = request.GetResponse();
Stream responseStream = response.GetResponseStream();
BinaryReader reader = new BinaryReader(responseStream);
MemoryStream memoryStream = new MemoryStream();
byte[] bytebuffer = new byte[BytesToRead];
int bytesRead = reader.Read(bytebuffer, 0, BytesToRead);
while (bytesRead > 0)
{
memoryStream.Write(bytebuffer, 0, bytesRead);
bytesRead = reader.Read(bytebuffer, 0, BytesToRead);
}
image.BeginInit();
memoryStream.Seek(0, SeekOrigin.Begin);
image.StreamSource = memoryStream;
image.EndInit();
myImage.Source = image;
}