<ListBox.ItemTemplate> <DataTemplate> <local:ImageTbk UCImgUrl="{Binding DataContext.ImgUrl, RelativeSource={RelativeSource Mode=FindAncestor,AncestorType=ListBoxItem}}" UCName="{Binding DataContext.Name,RelativeSource={RelativeSource Mode=FindAncestor,AncestorType=ListBoxItem}}" Height="800" Width="500"/> </DataTemplate> </ListBox.ItemTemplate>
//usercontrol.xaml <UserControl x:Class="WpfApp388.ImageTbk" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:local="clr-namespace:WpfApp388" mc:Ignorable="d" d:DesignHeight="450" d:DesignWidth="800"> <Grid> <Image Source="{Binding UCImgUrl,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}" /> <TextBlock Text="{Binding UCName,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}" VerticalAlignment="Center" HorizontalAlignment="Center" FontSize="100" Foreground="Red"/> </Grid> </UserControl> //usercontrol.xaml.cs using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows; using System.Windows.Controls; using System.Windows.Data; using System.Windows.Documents; using System.Windows.Input; using System.Windows.Media; using System.Windows.Media.Imaging; using System.Windows.Navigation; using System.Windows.Shapes; namespace WpfApp388 { /// <summary> /// Interaction logic for ImageTbk.xaml /// </summary> public partial class ImageTbk : UserControl { public ImageTbk() { InitializeComponent(); this.DataContext = this; } public string UCImgUrl { get { return (string)GetValue(UCImgUrlProperty); } set { SetValue(UCImgUrlProperty, value); } } // Using a DependencyProperty as the backing store for UCImgUrl. This enables animation, styling, binding, etc... public static readonly DependencyProperty UCImgUrlProperty = DependencyProperty.Register("UCImgUrl", typeof(string), typeof(ImageTbk), new PropertyMetadata("")); public string UCName { get { return (string)GetValue(UCNameProperty); } set { SetValue(UCNameProperty, value); } } // Using a DependencyProperty as the backing store for UCName. This enables animation, styling, binding, etc... public static readonly DependencyProperty UCNameProperty = DependencyProperty.Register("UCName", typeof(string), typeof(ImageTbk), new PropertyMetadata("")); } } //xaml <Window x:Class="WpfApp388.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:local="clr-namespace:WpfApp388" mc:Ignorable="d" WindowState="Maximized" Title="MainWindow" Height="450" Width="800"> <Window.Resources> <local:BookData x:Key="booksData"/> </Window.Resources> <Grid> <ListBox ItemsSource="{StaticResource booksData}" VirtualizingPanel.IsContainerVirtualizable="True" VirtualizingPanel.IsVirtualizing="True" VirtualizingPanel.CacheLength="100" VirtualizingPanel.CacheLengthUnit="Item" > <ListBox.ItemTemplate> <DataTemplate> <local:ImageTbk UCImgUrl="{Binding DataContext.ImgUrl, RelativeSource={RelativeSource Mode=FindAncestor,AncestorType=ListBoxItem}}" UCName="{Binding DataContext.Name,RelativeSource={RelativeSource Mode=FindAncestor,AncestorType=ListBoxItem}}" Height="500" Width="500"/> </DataTemplate> </ListBox.ItemTemplate> </ListBox> </Grid> </Window> //xaml.cs using System; using System.Collections.Generic; using System.Collections.ObjectModel; using System.ComponentModel; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows; using System.Windows.Controls; using System.Windows.Data; using System.Windows.Documents; using System.Windows.Input; using System.Windows.Media; using System.Windows.Media.Imaging; using System.Windows.Navigation; using System.Windows.Shapes; using System.IO; namespace WpfApp388 { /// <summary> /// Interaction logic for MainWindow.xaml /// </summary> public partial class MainWindow : Window { public MainWindow() { InitializeComponent(); } } public class BookVM : INotifyPropertyChanged { public event PropertyChangedEventHandler PropertyChanged; private void OnPropertyChanged(string propertyName) { var handler = PropertyChanged; if(handler!=null) { handler?.Invoke(this, new PropertyChangedEventArgs(propertyName)); } } private ObservableCollection<Book> books; public ObservableCollection<Book> BooksCollection { get { return books; } set { if(books!=value) { books = value; OnPropertyChanged(nameof(BooksCollection)); } } } } public class BookData:List<Book> { public BookData() { var imgsList = Directory.GetFiles(@"../../Images"); if(imgsList!=null && imgsList.Any()) { int imgsCount = imgsList.Count(); for(int i=0;i<100000;i++) { this.Add(new Book() { Id=i+1, Name=$"Name_{i+1}", Title=$"Title_{i+1}", Topic=$"Topic_{i+1}", ImgUrl = imgsList[i%imgsCount] }); } } } } public class Book { public int Id { get; set; } public string Name { get; set; } public string Title { get; set; } public string Topic { get; set; } public string ImgUrl { get; set; } } }