123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182 |
- using java.security;
- using System;
- using System.Collections.Generic;
- using System.ComponentModel;
- using System.Linq;
- using System.Runtime.CompilerServices;
- 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.Markup;
- using System.Windows.Media;
- using System.Windows.Media.Imaging;
- using System.Windows.Navigation;
- using System.Windows.Shapes;
- namespace InABox.WPF;
- /// <summary>
- /// Interaction logic for ZoomPanel.xaml
- /// </summary>
- public partial class ZoomPanel : ContentControl, INotifyPropertyChanged
- {
- private bool _showNavigationButtons = false;
- public bool ShowNavigationButtons
- {
- get => _showNavigationButtons;
- set
- {
- _showNavigationButtons = value;
- OnPropertyChanged();
- }
- }
- public double _minScale = 0.5;
- public double MinScale
- {
- get => _minScale;
- set
- {
- _minScale = value;
- if(_scale < _minScale)
- {
- Scale = _minScale;
- }
- }
- }
- public double _scale = 1;
- public double Scale
- {
- get => _scale;
- set
- {
- _scale = value;
- OnPropertyChanged();
- }
- }
- private ScrollViewer Scroll => (ScrollViewer)GetTemplateChild("PART_Scroll");
- private Border ContentBorder => (Border)GetTemplateChild("PART_ContentBorder");
- public double ScrollX
- {
- get => Scroll.HorizontalOffset;
- set
- {
- Scroll.ScrollToHorizontalOffset(value);
- }
- }
- public double ScrollY
- {
- get => Scroll.VerticalOffset;
- set
- {
- Scroll.ScrollToVerticalOffset(value);
- }
- }
- public double WheelSpeed { get; set; } = 0.002;
- public double PanAmount { get; set; } = 50;
- static ZoomPanel()
- {
- DefaultStyleKeyProperty.OverrideMetadata(typeof(ZoomPanel), new FrameworkPropertyMetadata(typeof(ZoomPanel)));
- }
- public override void OnApplyTemplate()
- {
- base.OnApplyTemplate();
- ((Button)GetTemplateChild("PART_ZoomInButton")).Click += ZoomInButton_Click;
- ((Button)GetTemplateChild("PART_ZoomOutButton")).Click += ZoomOutButton_Click;
- ((Button)GetTemplateChild("PART_LeftButton")).Click += LeftButton_Click;
- ((Button)GetTemplateChild("PART_RightButton")).Click += RightButton_Click;
- ((Button)GetTemplateChild("PART_UpButton")).Click += UpButton_Click;
- ((Button)GetTemplateChild("PART_DownButton")).Click += DownButton_Click;
- ((Button)GetTemplateChild("PART_DownButton")).Click += DownButton_Click;
- ((Border)GetTemplateChild("PART_ContentBorder")).MouseWheel += ItemsControl_MouseWheel;
- }
- public event PropertyChangedEventHandler? PropertyChanged;
- protected void OnPropertyChanged([CallerMemberName] string propertyName = "")
- {
- PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
- }
- private void ZoomInButton_Click(object sender, RoutedEventArgs e)
- {
- Scale *= 1.1;
- }
- private void ZoomOutButton_Click(object sender, RoutedEventArgs e)
- {
- Scale /= 1.1;
- }
- private void Pan(double x, double y)
- {
- ScrollX += x;
- ScrollY += y;
- //Origin = new(Origin.X - x, Origin.Y - y);
- }
- private void DownButton_Click(object sender, RoutedEventArgs e)
- {
- Pan(0, PanAmount);
- }
- private void UpButton_Click(object sender, RoutedEventArgs e)
- {
- Pan(0, -PanAmount);
- }
- private void RightButton_Click(object sender, RoutedEventArgs e)
- {
- Pan(PanAmount, 0);
- }
- private void LeftButton_Click(object sender, RoutedEventArgs e)
- {
- Pan(-PanAmount, 0);
- }
- private void ItemsControl_MouseWheel(object sender, MouseWheelEventArgs e)
- {
- if ((Keyboard.Modifiers & ModifierKeys.Control) == ModifierKeys.Control)
- {
- var pos = e.GetPosition(ContentBorder);
- var contentMPos = new Point(pos.X / Scale, pos.Y / Scale);
- if (e.Delta > 0)
- {
- Scale *= 1 + e.Delta * WheelSpeed;
- }
- else
- {
- Scale /= 1 + (-e.Delta) * WheelSpeed;
- }
- Scale = Math.Max(MinScale, Scale);
- var scaledPos = new Point(contentMPos.X * Scale, contentMPos.Y * Scale);
- var offset = scaledPos - pos;
- Pan(offset.X, offset.Y);
- e.Handled = true;
- }
- else if ((Keyboard.Modifiers & ModifierKeys.Shift) == ModifierKeys.Shift)
- {
- Pan(-e.Delta, 0);
- e.Handled = true;
- }
- }
- }
|