123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298 |
- using Microsoft.Win32;
- using Prism.Commands;
- using Prism.Mvvm;
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using ComPDFKitViewer.PdfViewer;
- using Prism.Regions;
- using DryIoc;
- using System.Diagnostics;
- using Prism.Services.Dialogs;
- using PDF_Office.CustomControl;
- using PDF_Office.Model;
- using System.Windows;
- using System.Windows.Controls;
- namespace PDF_Office.ViewModels
- {
- public class ViewContentViewModel : BindableBase, INavigationAware
- {
- #region 属性、变量
- private CPDFViewer PDFViewer { get; set; }
- private MainContentViewModel mainViewModel { get; set; }
- public IRegionManager region;
- public IDialogService dialogs;
- public string ViwerRegionName { get; set; }
- public string BOTARegionName { get; set; }
- public string PropertyRegionName { get; set; }
- public string ToolContentRegionName { get; set; }
- private int gridToolRow = 1;
-
-
-
- public int GridToolRow
- {
- get { return gridToolRow; }
- set
- {
- SetProperty(ref gridToolRow, value);
- }
- }
- private int gridToolRowSpan = 3;
-
-
-
- public int GridToolRowSpan
- {
- get { return gridToolRowSpan; }
- set
- {
- SetProperty(ref gridToolRowSpan, value);
- }
- }
- private Visibility toolContentVisible = Visibility.Visible;
-
-
-
-
- public Visibility ToolContentVisible
- {
- get { return toolContentVisible; }
- set
- {
- SetProperty(ref toolContentVisible, value);
- }
- }
-
-
-
- private bool isOpenFile = false;
-
-
-
- private double[] zoomLevel = { 1.00f, 10, 25, 50, 75, 100, 125, 150, 200, 300, 400, 600, 800, 1000 };
- #endregion
- #region 命令
- public DelegateCommand LoadFile { get; set; }
- public DelegateCommand Load { get; set; }
- public DelegateCommand<object> TabControlSelectionChangedCommand { get; set; }
- #endregion
- public ViewContentViewModel(IRegionManager regionManager, IDialogService dialogService)
- {
- region = regionManager;
- dialogs = dialogService;
- LoadFile = new DelegateCommand(loadFile);
- Load = new DelegateCommand(LoadControl);
- TabControlSelectionChangedCommand = new DelegateCommand<object>(TabControlSelectonChangedEvent);
- ViwerRegionName = Guid.NewGuid().ToString();
- BOTARegionName = Guid.NewGuid().ToString();
- PropertyRegionName = Guid.NewGuid().ToString();
-
- ToolContentVisible = Visibility.Visible;
- ToolContentRegionName = Guid.NewGuid().ToString();
- ToolContentVisible = Visibility.Collapsed;
- }
- private void LoadControl()
- {
-
- System.Windows.Application.Current.Dispatcher.BeginInvoke(System.Windows.Threading.DispatcherPriority.Send, new Action(() =>
- {
- region.RequestNavigate(BOTARegionName, "BOTAContent");
- }
- ));
- }
-
-
-
- private void loadFile()
- {
- PDFViewer.MouseWheelZoomHandler += PdfViewer_MouseWheelZoomHandler;
- region.AddToRegion(ViwerRegionName, PDFViewer);
- }
-
-
-
-
- private void TabControlSelectonChangedEvent(object e)
- {
- var args = e as SelectionChangedEventArgs;
- if (args != null)
- {
- var item = args.AddedItems[0] as TabItem;
- if (item.Name == "TabItemPageEdit")
- {
- EnterToolMode("PageEditContent");
- }
- else
- {
- ExitToolMode();
- }
- }
- }
- #region PDFViewer鼠标滚轮缩放事件
- public void PdfViewer_MouseWheelZoomHandler(object sender, bool e)
- {
- double newZoom = CheckZoomLevel(PDFViewer.ZoomFactor + (e ? 0.01 : -0.01), e);
- PDFViewer.Zoom(newZoom);
- }
- private double CheckZoomLevel(double zoom, bool IsGrowth)
- {
- double standardZoom = 100;
- if (zoom <= 0.01)
- {
- return 0.01;
- }
- if (zoom >= 10)
- {
- return 10;
- }
- zoom *= 100;
- for (int i = 0; i < zoomLevel.Length - 1; i++)
- {
- if (zoom > zoomLevel[i] && zoom <= zoomLevel[i + 1] && IsGrowth)
- {
- standardZoom = zoomLevel[i + 1];
- break;
- }
- if (zoom >= zoomLevel[i] && zoom < zoomLevel[i + 1] && !IsGrowth)
- {
- standardZoom = zoomLevel[i];
- break;
- }
- }
- return standardZoom / 100;
- }
- #endregion
- #region Navigate
- public void OnNavigatedTo(NavigationContext navigationContext)
- {
- if (isOpenFile)
- return;
- var mainVM = navigationContext.Parameters[ParameterNames.MainViewModel] as MainContentViewModel;
- if (mainVM != null)
- {
- mainViewModel = mainVM;
- }
- var pdfview = navigationContext.Parameters[ParameterNames.PDFViewer] as CPDFViewer;
- if (pdfview != null)
- {
- PDFViewer = pdfview;
- loadFile();
- }
- isOpenFile = true;
- }
- public bool IsNavigationTarget(NavigationContext navigationContext)
- {
- return true;
- }
- public void OnNavigatedFrom(NavigationContext navigationContext)
- {
- }
- #endregion
- #region 方法
-
-
-
-
- private void ShowToolContent(bool isPageEdit = true)
- {
-
- if (isPageEdit)
- {
- if (GridToolRow != 1)
- {
- GridToolRow = 1;
- }
- if (GridToolRowSpan != 3)
- {
- GridToolRowSpan = 3;
- }
- }
- else
- {
-
- GridToolRow = 0;
- GridToolRowSpan = 4;
- }
- ToolContentVisible = Visibility.Visible;
- }
-
-
-
-
-
- private void EnterToolMode(string targetToolMode, NavigationParameters valuePairs = null)
- {
- NavigationParameters param = new NavigationParameters();
- if (valuePairs == null)
- {
- param.Add(ParameterNames.PDFViewer, PDFViewer);
- param.Add(ParameterNames.ViewContentViewModel, this);
- }
- else
- {
- param = valuePairs;
- }
- region.RequestNavigate(ToolContentRegionName, targetToolMode, param);
- if (targetToolMode == "PageEditContent")
- {
- ShowToolContent();
- }
- else
- {
- ShowToolContent(false);
- }
- }
-
-
-
- public void ExitToolMode()
- {
- ToolContentVisible = Visibility.Collapsed;
- }
- #endregion
- }
- }
|