ConverterExcelDialog.xaml.cs 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. using ComPDFKit_Conversion.Options;
  2. using PDF_Office.CustomControl;
  3. using PDF_Office.Helper;
  4. using PDF_Office.ViewModels.Dialog.ConverterDialogs;
  5. using System.Diagnostics;
  6. using System.Linq;
  7. using System.Windows;
  8. using System.Windows.Controls;
  9. namespace PDF_Office.Views.Dialog.ConverterDialogs
  10. {
  11. /// <summary>
  12. /// Interaction logic for ConverterExcelDialog
  13. /// </summary>
  14. public partial class ConverterExcelDialog : UserControl
  15. {
  16. public ConverterExcelDialog()
  17. {
  18. InitializeComponent();
  19. }
  20. private void ConverterPreview_Loaded(object sender, System.Windows.RoutedEventArgs e)
  21. {
  22. ConverterPreview.document = ((ConverterExcelDialogViewModel)this.DataContext).currentViewer.Document;
  23. char[] enumerationSeparator = new char[] { ',' };
  24. char[] rangeSeparator = new char[] { '-' };
  25. if (!CommonHelper.GetPagesInRange(ref ConverterPreview.PageIndexLists, "1-" + ConverterPreview.document.PageCount.ToString(), ConverterPreview.document.PageCount, enumerationSeparator, rangeSeparator))
  26. { //TODO
  27. Trace.WriteLine("输入不对");
  28. MessageBoxEx.Show("输入不对");
  29. return;
  30. }
  31. ConverterPreview.AwaitRenderBitmap(ConverterPreview.document);
  32. ConverterPreview.PageIndex.Text = ConverterPreview.document.PageCount.ToString();
  33. }
  34. private void PageRangeComboBox_Loaded(object sender, RoutedEventArgs e)
  35. {
  36. PageRangeComboBox.CurrentPage = true;
  37. if (PageRangeComboBox.CurrentPage)
  38. {
  39. ComboBoxItem comboBoxItem = new ComboBoxItem();
  40. comboBoxItem.Content = "当前页面";
  41. PageRangeComboBox.writableComboBox.Items.Insert(1, comboBoxItem);
  42. }
  43. PageRangeComboBox.writableComboBox.SelectionChanged += PageRangeComboBox_SelectionChanged;
  44. PageRangeComboBox.writableTextBox.TextChanged += WritableTextBox_TextChanged;
  45. }
  46. private void WritableTextBox_TextChanged(object sender, TextChangedEventArgs e)
  47. {
  48. string PageRangeSelectIndex = ((ConverterExcelDialogViewModel)this.DataContext).PageRangeSelectIndex;
  49. var currentViewer = ((ConverterExcelDialogViewModel)this.DataContext).currentViewer;
  50. string PageRange = "";
  51. var PageRangeText = ((ConverterExcelDialogViewModel)this.DataContext).PageRangeText;
  52. HomePageEditHelper.GetPagerange(PageRangeSelectIndex, currentViewer, ref PageRange, PageRangeText, true);
  53. char[] enumerationSeparator = new char[] { ',' };
  54. char[] rangeSeparator = new char[] { '-' };
  55. if (!CommonHelper.GetPagesInRange(ref ConverterPreview.PageIndexLists, PageRange, currentViewer.Document.PageCount, enumerationSeparator, rangeSeparator))
  56. { //TODO
  57. ConverterPreview.PageIndexLists.Add(0);
  58. return;
  59. }
  60. else
  61. {
  62. ConverterPreview.PageIndex.Text = (ConverterPreview.PageIndexLists.Last<int>() + 1).ToString();
  63. ConverterPreview.CurrentIndex = 0;
  64. ConverterPreview.CurrentPage.Text = (ConverterPreview.PageIndexLists[ConverterPreview.CurrentIndex] + 1).ToString();
  65. ConverterPreview.AwaitRenderBitmap(ConverterPreview.document);
  66. }
  67. }
  68. private void PageRangeComboBox_SelectionChanged(object sender, SelectionChangedEventArgs e)
  69. {
  70. string PageRangeSelectIndex = ((ConverterExcelDialogViewModel)this.DataContext).PageRangeSelectIndex;
  71. var currentViewer = ((ConverterExcelDialogViewModel)this.DataContext).currentViewer;
  72. string PageRange = "";
  73. var PageRangeText = ((ConverterExcelDialogViewModel)this.DataContext).PageRangeText;
  74. if (PageRangeSelectIndex == "0" || PageRangeSelectIndex == "2" || PageRangeSelectIndex == "3")
  75. {
  76. HomePageEditHelper.GetPagerange(PageRangeSelectIndex, currentViewer, ref PageRange, PageRangeText, true);
  77. char[] enumerationSeparator = new char[] { ',' };
  78. char[] rangeSeparator = new char[] { '-' };
  79. if (!CommonHelper.GetPagesInRange(ref ConverterPreview.PageIndexLists, PageRange, currentViewer.Document.PageCount, enumerationSeparator, rangeSeparator))
  80. { //TODO
  81. Trace.WriteLine("输入不对");
  82. MessageBoxEx.Show("输入不对");
  83. return;
  84. }
  85. }
  86. if (PageRangeSelectIndex == "1")
  87. {
  88. char[] enumerationSeparator = new char[] { ',' };
  89. char[] rangeSeparator = new char[] { '-' };
  90. if (!CommonHelper.GetPagesInRange(ref ConverterPreview.PageIndexLists, (ConverterPreview.PageIndexLists[ConverterPreview.CurrentIndex] + 1).ToString(), currentViewer.Document.PageCount, enumerationSeparator, rangeSeparator))
  91. { //TODO
  92. Trace.WriteLine("输入不对");
  93. MessageBoxEx.Show("输入不对");
  94. return;
  95. }
  96. ((ConverterExcelDialogViewModel)this.DataContext).CurrentPageIndex = (ConverterPreview.PageIndexLists.Last<int>() + 1).ToString();
  97. }
  98. ConverterPreview.PageIndex.Text = (ConverterPreview.PageIndexLists.Last<int>() + 1).ToString();
  99. ConverterPreview.CurrentIndex = 0;
  100. ConverterPreview.CurrentPage.Text = (ConverterPreview.PageIndexLists[ConverterPreview.CurrentIndex] + 1).ToString();
  101. ConverterPreview.AwaitRenderBitmap(ConverterPreview.document);
  102. }
  103. private void OnlyTableComboBox_SelectionChanged(object sender, SelectionChangedEventArgs e)
  104. {
  105. switch (OnlyTableComboBox.SelectedIndex) {
  106. case 0:
  107. ((ConverterExcelDialogViewModel)this.DataContext).ConverterExcelModel.excelOption = ((ConverterExcelDialogViewModel)this.DataContext).ConverterExcelModel.ExcelOptions(WorksheetOptions.ForEachTable, ContentOptions.OnlyTable);
  108. break;
  109. case 1:
  110. ((ConverterExcelDialogViewModel)this.DataContext).ConverterExcelModel.excelOption = ((ConverterExcelDialogViewModel)this.DataContext).ConverterExcelModel.ExcelOptions(WorksheetOptions.ForEachPage, ContentOptions.OnlyTable);
  111. break;
  112. case 2:
  113. ((ConverterExcelDialogViewModel)this.DataContext).ConverterExcelModel.excelOption = ((ConverterExcelDialogViewModel)this.DataContext).ConverterExcelModel.ExcelOptions(WorksheetOptions.ForTheDocument, ContentOptions.OnlyTable);
  114. break;
  115. default:
  116. break;
  117. }
  118. }
  119. }
  120. }