//xaml <Window x:Class="WpfApp145.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:WpfApp145" mc:Ignorable="d" WindowState="Maximized" Title="MainWindow" Height="450" Width="800"> <Grid> <Grid.ColumnDefinitions> <ColumnDefinition Width="200"/> <ColumnDefinition/> </Grid.ColumnDefinitions> <ListBox Grid.Column="0" x:Name="lbx" SelectedIndex="0" SelectionChanged="lbx_SelectionChanged" > <ListBox.ItemTemplate> <DataTemplate> <Image Source="{Binding Content,RelativeSource={RelativeSource AncestorType=ListBoxItem}}" Width="200" Height="500"/> </DataTemplate> </ListBox.ItemTemplate> </ListBox> <Image Grid.Column="1" x:Name="img" Source="{Binding SelectedItem,ElementName=lbx}" ClipToBounds="True" MouseDown="img_MouseDown" MouseMove="img_MouseMove" MouseUp="img_MouseUp" MouseWheel="img_MouseWheel"> <Image.RenderTransform> <TransformGroup> <ScaleTransform x:Name="scaler"/> <TranslateTransform x:Name="translater"/> </TransformGroup> </Image.RenderTransform> </Image> </Grid> </Window> //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; using System.IO; namespace WpfApp145 { /// <summary> /// Interaction logic for MainWindow.xaml /// </summary> public partial class MainWindow : Window { public MainWindow() { InitializeComponent(); InitLbx(); } private void InitLbx() { var files = Directory.GetFiles(@"..\..\Images", "*", SearchOption.AllDirectories); lbx.ItemsSource = files; } Point prePoint { get; set; } bool isMoving { get; set; } private void img_MouseDown(object sender, MouseButtonEventArgs e) { prePoint = e.GetPosition(img); } private void img_MouseMove(object sender, MouseEventArgs e) { isMoving = true; } private void img_MouseUp(object sender, MouseButtonEventArgs e) { if (isMoving && e.ChangedButton == MouseButton.Left && e.ButtonState == MouseButtonState.Released) { Point newPoint = e.GetPosition(img); translater.X += newPoint.X - prePoint.X; translater.Y += newPoint.Y - prePoint.Y; isMoving = false; } } private void img_MouseWheel(object sender, MouseWheelEventArgs e) { if (e.Delta > 0) { scaler.ScaleX *= 1.2; scaler.ScaleY *= 1.2; } else { scaler.ScaleX /= 1.2; scaler.ScaleY /= 1.2; } scaler.CenterX = e.GetPosition(img).X; scaler.CenterY = e.GetPosition(img).Y; } private void lbx_SelectionChanged(object sender, SelectionChangedEventArgs e) { scaler.ScaleX = 1.0; scaler.ScaleY = 1.0; translater.X = 0; translater.Y = 0; } } }