Skip to content

Commit

Permalink
More natural scroll behaviour
Browse files Browse the repository at this point in the history
  • Loading branch information
xupefei committed Jul 22, 2017
1 parent 86dacf6 commit b0e8a29
Show file tree
Hide file tree
Showing 4 changed files with 69 additions and 6 deletions.
16 changes: 13 additions & 3 deletions QuickLook.Plugin/QuickLook.Plugin.ImageViewer/ImagePanel.xaml.cs
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@ public ImagePanel()
viewPanel.MouseLeftButtonDown += ViewPanel_MouseLeftButtonDown;
viewPanel.MouseMove += ViewPanel_MouseMove;

viewPanel.ManipulationInertiaStarting += ViewPanel_ManipulationInertiaStarting;
viewPanel.ManipulationStarting += ViewPanel_ManipulationStarting;
viewPanel.ManipulationDelta += ViewPanel_ManipulationDelta;
}
Expand Down Expand Up @@ -128,7 +129,16 @@ public BitmapSource Source
private void ImagePanel_SizeChanged(object sender, SizeChangedEventArgs e)
{
if (ZoomToFit)
DoZoomToFit(false);
DoZoomToFit();
}

private void ViewPanel_ManipulationInertiaStarting(object sender, ManipulationInertiaStartingEventArgs e)
{
e.TranslationBehavior = new InertiaTranslationBehavior
{
InitialVelocity = e.InitialVelocities.LinearVelocity,
DesiredDeceleration = 10.0 * 96.0 / (1000.0 * 1000.0)
};
}

private void ViewPanel_ManipulationStarting(object sender, ManipulationStartingEventArgs e)
Expand Down Expand Up @@ -220,15 +230,15 @@ public void SetScrollPosition(Point point)
viewPanel.ScrollToVerticalOffset(point.Y);
}

public void DoZoomToFit(bool suppressEvent)
public void DoZoomToFit()
{
if (viewPanelImage.Source == null)
return;

var factor = Math.Min(viewPanel.ActualWidth / viewPanelImage.Source.Width,
viewPanel.ActualHeight / viewPanelImage.Source.Height);

Zoom(factor, true, suppressEvent);
Zoom(factor, true);
}

public void ResetZoom()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,8 @@ public partial class PdfViewerControl : UserControl, INotifyPropertyChanged, IDi
{
private const double MinZoomFactor = 0.1d;
private const double MaxZoomFactor = 3d;
private int _changePageDeltaSum;

private bool _pdfLoaded;
private double _viewRenderFactor = 1d;

Expand Down Expand Up @@ -103,9 +105,23 @@ private void NavigatePage(object sender, int delta)

const double tolerance = 0.0001d;
if (Math.Abs(pos.Y) < tolerance && delta > 0)
{
_changePageDeltaSum += delta;
if (Math.Abs(_changePageDeltaSum) < 20)
return;

PrevPage();
else if (Math.Abs(pos.Y - size.Height) < tolerance && delta < 0)
_changePageDeltaSum = 0;
}
else if (Math.Abs(pos.Y - size.Height) < tolerance && delta < -0)
{
_changePageDeltaSum += delta;
if (Math.Abs(_changePageDeltaSum) < 20)
return;

NextPage();
_changePageDeltaSum = 0;
}
}

private void NextPage()
Expand Down Expand Up @@ -193,7 +209,7 @@ public void LoadPdf(string path)
OnPropertyChanged("PageIds");

CurrentPage = 0;
pagePanel.DoZoomToFit(true);
pagePanel.DoZoomToFit();
}

protected virtual void OnPropertyChanged([CallerMemberName] string propertyName = null)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,6 @@
UseLayoutRounding="True">
<Grid>
<avalonEdit:TextEditor x:Name="viewer" Background="#00FFFFFF" FontSize="14" ShowLineNumbers="True"
WordWrap="True" IsReadOnly="True" />
WordWrap="True" IsReadOnly="True" IsManipulationEnabled="True" />
</Grid>
</UserControl>
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
using System.IO;
using System.Text;
using System.Windows.Controls;
using System.Windows.Input;
using System.Windows.Media;
using ICSharpCode.AvalonEdit.Highlighting;

Expand All @@ -32,12 +33,48 @@ public TextViewerPanel(string path, ContextObject context)
{
InitializeComponent();

viewer.ManipulationInertiaStarting += Viewer_ManipulationInertiaStarting;
viewer.ManipulationStarting += Viewer_ManipulationStarting;
viewer.ManipulationDelta += Viewer_ManipulationDelta;

viewer.PreviewMouseWheel += Viewer_MouseWheel;

viewer.FontFamily =
new FontFamily(context.GetString("Editor_FontFamily", failsafe: "Consolas"));

LoadFile(path);
}

private void Viewer_ManipulationInertiaStarting(object sender, ManipulationInertiaStartingEventArgs e)
{
e.TranslationBehavior = new InertiaTranslationBehavior
{
InitialVelocity = e.InitialVelocities.LinearVelocity,
DesiredDeceleration = 10.0 * 96.0 / (1000.0 * 1000.0)
};
}

private void Viewer_MouseWheel(object sender, MouseWheelEventArgs e)
{
e.Handled = true;

viewer.ScrollToVerticalOffset(viewer.VerticalOffset - e.Delta);
}

private void Viewer_ManipulationDelta(object sender, ManipulationDeltaEventArgs e)
{
e.Handled = true;

var delta = e.DeltaManipulation;
viewer.ScrollToVerticalOffset(viewer.VerticalOffset - delta.Translation.Y);
}

private void Viewer_ManipulationStarting(object sender, ManipulationStartingEventArgs e)
{
e.ManipulationContainer = this;
e.Mode = ManipulationModes.Translate;
}

private void LoadFile(string path)
{
using (var s = new FileStream(path, FileMode.Open, FileAccess.Read, FileShare.Read))
Expand Down

0 comments on commit b0e8a29

Please sign in to comment.