ConverterExcelDialogViewModel.cs 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725
  1. using ComDocumentAIKit;
  2. using ComPDFKit_Conversion.Options;
  3. using ComPDFKitViewer.PdfViewer;
  4. using Microsoft.Office.Interop.Excel;
  5. using PDF_Master.CustomControl;
  6. using PDF_Master.Helper;
  7. using PDF_Master.Model;
  8. using PDF_Master.Model.Dialog.ConverterDialogs;
  9. using PDF_Master.Model.Dialog.HomePageToolsDialogs.HomePageBatchProcessing;
  10. using PDF_Master.Properties;
  11. using PDF_Master.ViewModels.Dialog.HomePageToolsDialogs.HomePageBatchProcessing.HomePageConverter;
  12. using Prism.Commands;
  13. using Prism.Mvvm;
  14. using Prism.Services.Dialogs;
  15. using System;
  16. using System.Collections.Generic;
  17. using System.Diagnostics;
  18. using System.Globalization;
  19. using System.IO;
  20. using System.Linq;
  21. using System.Windows;
  22. using System.Windows.Forms;
  23. using DialogResult = Prism.Services.Dialogs.DialogResult;
  24. namespace PDF_Master.ViewModels.Dialog.ConverterDialogs
  25. {
  26. public class ConverterExcelDialogViewModel : BindableBase, IDialogAware
  27. {
  28. #region 文案
  29. private string T_title;
  30. public string T_Title
  31. {
  32. get { return T_title; }
  33. set
  34. {
  35. SetProperty(ref T_title, value);
  36. }
  37. }
  38. private string T_yes;
  39. public string T_YES
  40. {
  41. get { return T_yes; }
  42. set
  43. {
  44. SetProperty(ref T_yes, value);
  45. }
  46. }
  47. private string T_no;
  48. public string T_No
  49. {
  50. get { return T_no; }
  51. set
  52. {
  53. SetProperty(ref T_no, value);
  54. }
  55. }
  56. private string T_onlyTables;
  57. public string T_OnlyTables
  58. {
  59. get { return T_onlyTables; }
  60. set
  61. {
  62. SetProperty(ref T_onlyTables, value);
  63. }
  64. }
  65. private string T_allContents;
  66. public string T_AllContents
  67. {
  68. get { return T_allContents; }
  69. set
  70. {
  71. SetProperty(ref T_allContents, value);
  72. }
  73. }
  74. private string T_eachPageAllContents;
  75. public string T_EachPageAllContents
  76. {
  77. get { return T_eachPageAllContents; }
  78. set
  79. {
  80. SetProperty(ref T_eachPageAllContents, value);
  81. }
  82. }
  83. private string T_fileAllContents;
  84. public string T_FileAllContents
  85. {
  86. get { return T_fileAllContents; }
  87. set
  88. {
  89. SetProperty(ref T_fileAllContents, value);
  90. }
  91. }
  92. private string T_eachTableOnlyTables;
  93. public string T_EachTableOnlyTables
  94. {
  95. get { return T_eachTableOnlyTables; }
  96. set
  97. {
  98. SetProperty(ref T_eachTableOnlyTables, value);
  99. }
  100. }
  101. private string T_eachPageOnlyTables;
  102. public string T_EachPageOnlyTables
  103. {
  104. get { return T_eachPageOnlyTables; }
  105. set
  106. {
  107. SetProperty(ref T_eachPageOnlyTables, value);
  108. }
  109. }
  110. private string T_fileOnlyTables;
  111. public string T_FileOnlyTables
  112. {
  113. get { return T_fileOnlyTables; }
  114. set
  115. {
  116. SetProperty(ref T_fileOnlyTables, value);
  117. }
  118. }
  119. private string T_onlyText;
  120. public string T_OnlyText
  121. {
  122. get { return T_onlyText; }
  123. set
  124. {
  125. SetProperty(ref T_onlyText, value);
  126. }
  127. }
  128. private string T_settings;
  129. public string T_Settings
  130. {
  131. get { return T_settings; }
  132. set
  133. {
  134. SetProperty(ref T_settings, value);
  135. }
  136. }
  137. private string T_pageRange;
  138. public string T_PageRange
  139. {
  140. get { return T_pageRange; }
  141. set
  142. {
  143. SetProperty(ref T_pageRange, value);
  144. }
  145. }
  146. private string _TextUpgrade;
  147. public string TextUpgrade
  148. {
  149. get { return _TextUpgrade; }
  150. set { _TextUpgrade = value; }
  151. }
  152. private void IntString()
  153. {
  154. TextUpgrade = App.ServiceLoader.GetString("TextUpgrade");
  155. T_Title = App.MainPageLoader.GetString("Convert_PDFToExcelTitle");
  156. T_YES = App.MainPageLoader.GetString("Convert_Yes");
  157. T_No = App.MainPageLoader.GetString("Convert_No");
  158. T_AllContents = App.MainPageLoader.GetString("Convert_PDFToExcelAllContents");
  159. T_EachPageAllContents = App.MainPageLoader.GetString("Convert_PDFToExcelAllContentsEachPage");
  160. T_FileAllContents = App.MainPageLoader.GetString("Convert_PDFToExcelAllContentsFile");
  161. T_OnlyTables = App.MainPageLoader.GetString("Convert_PDFToExcelAllOnlyTables");
  162. T_EachTableOnlyTables = App.MainPageLoader.GetString("Convert_PDFToExcelAllOnlyTablesEachTable");
  163. T_EachPageOnlyTables = App.MainPageLoader.GetString("Convert_PDFToExcelAllOnlyTablesEachPage");
  164. T_FileOnlyTables = App.MainPageLoader.GetString("Convert_PDFToExcelAllOnlyTablesFile");
  165. T_OnlyText = App.MainPageLoader.GetString("Convert_PDFToExcelOnlyText");
  166. T_Settings = App.MainPageLoader.GetString("Convert_PDFToExcelSettings");
  167. T_PageRange = App.MainPageLoader.GetString("Convert_PDFPageRange");
  168. }
  169. #endregion 参数和属性
  170. public string Title => "";
  171. public event Action<IDialogResult> RequestClose;
  172. #region 参数和属性
  173. public ConverterExcelDialogModel ConverterExcelModel = new ConverterExcelDialogModel();
  174. public CPDFViewer currentViewer;
  175. public string CurrentPageIndex = "1";
  176. public bool IsCurrentPageIndex = false;
  177. public IDialogService dialogs;
  178. public string PageRangeText { set; get; } = "0";
  179. public string PageRangeSelectIndex { set; get; } = "0";
  180. private int _anyContentSelectIndex = 0;
  181. public int AnyContentSelectIndex
  182. {
  183. get { return _anyContentSelectIndex; }
  184. set
  185. {
  186. SetProperty(ref _anyContentSelectIndex, value);
  187. AnyContent(_anyContentSelectIndex);
  188. }
  189. }
  190. private int _onlyTableSelectIndex = 0;
  191. public int OnlyTableSelectIndex
  192. {
  193. get { return _onlyTableSelectIndex; }
  194. set
  195. {
  196. SetProperty(ref _onlyTableSelectIndex, value);
  197. OnlyTable(_onlyTableSelectIndex);
  198. }
  199. }
  200. private int maxPageRange = 0;
  201. public int MaxPageRange
  202. {
  203. get { return maxPageRange; }
  204. set
  205. {
  206. SetProperty(ref maxPageRange, value);
  207. }
  208. }
  209. private bool oCRCheckBoxIsCheckBox = true;
  210. public bool OCRCheckBoxIsCheckBox
  211. {
  212. get { return oCRCheckBoxIsCheckBox; }
  213. set
  214. {
  215. SetProperty(ref oCRCheckBoxIsCheckBox, value);
  216. ConverterExcelModel.Options.IsAllowOCR = oCRCheckBoxIsCheckBox;
  217. }
  218. }
  219. private bool oCRIsEnable = true;
  220. public bool OCRIsEnable
  221. {
  222. get { return oCRIsEnable; }
  223. set
  224. {
  225. SetProperty(ref oCRIsEnable, value);
  226. if (value == true)
  227. {
  228. ConverterExcelModel.Options.IsAllowOCR = OCRCheckBoxIsCheckBox;
  229. }
  230. else
  231. {
  232. ConverterExcelModel.Options.IsAllowOCR = false;
  233. }
  234. }
  235. }
  236. private int languageSelectedIndex = 2;
  237. public int LanguageSelectedIndex
  238. {
  239. get { return languageSelectedIndex; }
  240. set
  241. {
  242. SetProperty(ref languageSelectedIndex, value);
  243. SelectLanguage(languageSelectedIndex);
  244. }
  245. }
  246. private Dictionary<string, string> CheckPageSelect = new Dictionary<string, string>();
  247. private void InitCheckPageSelect()
  248. {
  249. CheckPageSelect.Clear();
  250. if (!IsCurrentPageIndex)
  251. {
  252. CheckPageSelect.Add("0", "0");
  253. CheckPageSelect.Add("1", "1");
  254. CheckPageSelect.Add("2", "2");
  255. CheckPageSelect.Add("3", "3");
  256. CheckPageSelect.Add("4", "4");
  257. }
  258. else
  259. {
  260. CheckPageSelect.Add("0", "0");
  261. CheckPageSelect.Add("1", "-2");
  262. CheckPageSelect.Add("2", "1");
  263. CheckPageSelect.Add("3", "2");
  264. CheckPageSelect.Add("4", "3");
  265. }
  266. }
  267. private Visibility limitationsConvertVisible = Visibility.Hidden;
  268. public Visibility LimitationsConvertVisible
  269. {
  270. get { return limitationsConvertVisible; }
  271. set
  272. {
  273. SetProperty(ref limitationsConvertVisible, value);
  274. }
  275. }
  276. #endregion
  277. #region 委托声明
  278. public DelegateCommand<string> RadioButtonCommand { get; set; }
  279. public DelegateCommand CancelCommand { get; set; }
  280. public DelegateCommand ConverterCommnad { get; set; }
  281. public DelegateCommand<object> CmbPageSelectionChanged { get; set; }
  282. public DelegateCommand<object> CmbPageTextChanged { get; set; }
  283. public DelegateCommand BatchConverterCommand { get; set; }
  284. public DelegateCommand<object> PreviewCancelDownCommand { get; set; }
  285. public DelegateCommand SetCustomPageRangeCommand { get; set; }
  286. public DelegateCommand UnlockMouseDownCommand { get; set; }
  287. #endregion
  288. public ConverterExcelDialogViewModel(IDialogService dialogService)
  289. {
  290. IntString();
  291. CancelCommand = new DelegateCommand(cancel);
  292. ConverterCommnad = new DelegateCommand(converter);
  293. RadioButtonCommand = new DelegateCommand<string>(radiobutton);
  294. SetCustomPageRangeCommand = new DelegateCommand(SetCustomPageRange);
  295. CmbPageSelectionChanged = new DelegateCommand<object>(CmbPageSelectionChangedEvent);
  296. CmbPageTextChanged = new DelegateCommand<object>(CmbPageTextChangedEvent);
  297. PreviewCancelDownCommand = new DelegateCommand<object>(PreviewCancelDown);
  298. BatchConverterCommand = new DelegateCommand(BatchConverter);
  299. UnlockMouseDownCommand = new DelegateCommand(UnlockMouseDown);
  300. dialogs = dialogService;
  301. }
  302. #region 逻辑函数
  303. public void SetCustomPageRange()
  304. {
  305. if (PageRangeSelectIndex == CheckPageSelect["4"])
  306. {
  307. List<int> PageIndexLists = new List<int>();
  308. if (!CommonHelper.GetPagesInRange(ref PageIndexLists, PageRangeText, currentViewer.Document.PageCount, new char[] { ',' }, new char[] { '-' }))
  309. { //TODO
  310. //AlertsMessage alertsMessage = new AlertsMessage();
  311. //alertsMessage.ShowDialog("", App.MainPageLoader.GetString("PageRangeWarning"), App.ServiceLoader.GetString("Text_ok"));
  312. //if (alertsMessage.result == ContentResult.Ok)
  313. //{
  314. // return;
  315. //}
  316. //else
  317. //{
  318. // //this.eventAggregator.GetEvent<DeleteWatermarkEvent>().Publish(new EnumDeleteUnicode
  319. // //{
  320. // // Unicode = Unicode,
  321. // // Status = EnumDelete.StatusCreate
  322. // //});
  323. // return;
  324. //}
  325. }
  326. }
  327. }
  328. private void cancel()
  329. {
  330. RequestClose.Invoke(new DialogResult(ButtonResult.Cancel));
  331. }
  332. private void PreviewCancelDown(object e)
  333. {
  334. var PageRangeComboBox = e as WritableComboBox;
  335. if (PageRangeComboBox != null)
  336. {
  337. PageRangeComboBox.IsloseFocus = false;
  338. }
  339. }
  340. private void converter()
  341. {
  342. if (PageRangeSelectIndex == CheckPageSelect["4"])
  343. {
  344. List<int> PageIndexLists = new List<int>();
  345. if (!CommonHelper.GetPagesInRange(ref PageIndexLists, PageRangeText, currentViewer.Document.PageCount, new char[] { ',' }, new char[] { '-' }))
  346. { //TODO
  347. AlertsMessage alertsMessage = new AlertsMessage();
  348. alertsMessage.ShowDialog("", App.MainPageLoader.GetString("PageRangeWarning"), App.ServiceLoader.GetString("Text_ok"));
  349. if (alertsMessage.result == ContentResult.Ok)
  350. {
  351. return;
  352. }
  353. else
  354. {
  355. //this.eventAggregator.GetEvent<DeleteWatermarkEvent>().Publish(new EnumDeleteUnicode
  356. //{
  357. // Unicode = Unicode,
  358. // Status = EnumDelete.StatusCreate
  359. //});
  360. return;
  361. }
  362. }
  363. }
  364. System.Windows.Forms.SaveFileDialog sfd = new System.Windows.Forms.SaveFileDialog();
  365. /*
  366. *设置这个对话框的起始保存路径
  367. */
  368. sfd.InitialDirectory = currentViewer.Document.FilePath;
  369. /*
  370. *设置保存的文件的类型,注意过滤器的语法 例子:“文件类型|*.后缀名;*.后缀名;”
  371. */
  372. sfd.Filter = "Excel|*.xlsx;";
  373. /*
  374. *调用ShowDialog()方法显示该对话框,该方法的返回值代表用户是否点击了确定按钮
  375. */
  376. sfd.FileName = currentViewer.Document.FileName + ".xlsx";
  377. /*
  378. * 做一些工作
  379. */
  380. if (sfd.ShowDialog() == System.Windows.Forms.DialogResult.OK)
  381. {
  382. ConverterExcelModel.OutputPath = sfd.FileName;
  383. try { if (File.Exists(ConverterExcelModel.OutputPath)) File.Delete(ConverterExcelModel.OutputPath); }
  384. catch
  385. {
  386. AlertsMessage alertsMessage = new AlertsMessage();
  387. alertsMessage.ShowDialog("", App.MainPageLoader.GetString("FileNotExistWarning"), App.ServiceLoader.GetString("Text_ok"));
  388. return;
  389. }
  390. }
  391. else
  392. {
  393. return;
  394. }
  395. HomePageEditHelper.GetPagerange(PageRangeSelectIndex, currentViewer, ref ConverterExcelModel.PageRange, PageRangeText, !IsCurrentPageIndex, CurrentPageIndex);
  396. if (ConverterExcelModel.PageRange == "")
  397. {
  398. Trace.WriteLine("输入不对");
  399. AlertsMessage alertsMessage = new AlertsMessage();
  400. alertsMessage.ShowDialog("", App.MainPageLoader.GetString("PageRangeWarning"), App.ServiceLoader.GetString("Text_ok"));
  401. return;
  402. }
  403. char[] enumerationSeparator = new char[] { ',' };
  404. char[] rangeSeparator = new char[] { '-' };
  405. if (!CommonHelper.GetPagesInRange(ref ConverterExcelModel.PageIndexLists, ConverterExcelModel.PageRange, currentViewer.Document.PageCount, enumerationSeparator, rangeSeparator))
  406. { //TODO
  407. Trace.WriteLine("输入不对");
  408. AlertsMessage alertsMessage = new AlertsMessage();
  409. alertsMessage.ShowDialog("", App.MainPageLoader.GetString("PageRangeWarning"), App.ServiceLoader.GetString("Text_ok"));
  410. return;
  411. }
  412. ConverterExcelModel.excelOptions = ConverterExcelModel.ExcelOptions();
  413. //DialogParameters value = new DialogParameters();
  414. //value.Add(ParameterNames.ConverterType, "Excel");
  415. //value.Add(ParameterNames.ConverterTypeModel, ConverterExcelModel);
  416. var dialogresult = new DialogResult(ButtonResult.OK);
  417. dialogresult.Parameters.Add(ParameterNames.ConverterType, "Excel");
  418. dialogresult.Parameters.Add(ParameterNames.ConverterTypeModel, ConverterExcelModel);
  419. RequestClose.Invoke(dialogresult);
  420. //RequestClose?.Invoke(new DialogResult(ButtonResult.OK));
  421. //dialogs.ShowDialog(DialogNames.ConverterProgressBarDialog, value, e =>
  422. //{
  423. //});
  424. }
  425. private void CmbPageSelectionChangedEvent(object e)
  426. {
  427. ///这里采用的是将预览UI控件传递过来的方式,为下下策
  428. ///正确的方式应该是 通过声明一些属性,再通过绑定来更新预览控件对应值的形式
  429. ///但是目前发现自定义控件的依赖属性绑定有些问题,因此先用此方法,将业务逻辑代码先调整到VM里
  430. var ConverterPreview = e as PageTurningPreview;
  431. if (ConverterPreview != null)
  432. {
  433. string PageRangeSelectIndex = this.PageRangeSelectIndex;
  434. var currentViewer = this.currentViewer;
  435. string PageRange = "";
  436. var PageRangeText = this.PageRangeText;
  437. if (PageRangeSelectIndex == CheckPageSelect["0"] || PageRangeSelectIndex == CheckPageSelect["2"] || PageRangeSelectIndex == CheckPageSelect["3"] || PageRangeSelectIndex == CheckPageSelect["4"])
  438. {
  439. if (PageRangeSelectIndex == CheckPageSelect["4"]) { HomePageEditHelper.GetPagerange("0", currentViewer, ref PageRange, PageRangeText, !IsCurrentPageIndex); } else { HomePageEditHelper.GetPagerange(PageRangeSelectIndex, currentViewer, ref PageRange, PageRangeText, !IsCurrentPageIndex); }
  440. char[] enumerationSeparator = new char[] { ',' };
  441. char[] rangeSeparator = new char[] { '-' };
  442. if (!CommonHelper.GetPagesInRange(ref ConverterPreview.PageIndexLists, PageRange, currentViewer.Document.PageCount, enumerationSeparator, rangeSeparator))
  443. { //TODO
  444. ConverterPreview.PageIndexLists.Add(0);
  445. Trace.WriteLine("输入不对");
  446. AlertsMessage alertsMessage = new AlertsMessage();
  447. alertsMessage.ShowDialog("", App.MainPageLoader.GetString("PageRangeWarning"), App.ServiceLoader.GetString("Text_ok"));
  448. return;
  449. }
  450. }
  451. if (PageRangeSelectIndex == CheckPageSelect["1"])
  452. {
  453. char[] enumerationSeparator = new char[] { ',' };
  454. char[] rangeSeparator = new char[] { '-' };
  455. if (!CommonHelper.GetPagesInRange(ref ConverterPreview.PageIndexLists, (currentViewer.CurrentIndex + 1).ToString()
  456. , currentViewer.Document.PageCount, enumerationSeparator, rangeSeparator))
  457. { //TODO
  458. Trace.WriteLine("输入不对");
  459. AlertsMessage alertsMessage = new AlertsMessage();
  460. alertsMessage.ShowDialog("", App.MainPageLoader.GetString("PageRangeWarning"), App.ServiceLoader.GetString("Text_ok"));
  461. return;
  462. }
  463. this.CurrentPageIndex = (ConverterPreview.PageIndexLists.Last<int>() + 1).ToString();
  464. }
  465. // ConverterPreview.PageIndex.Text = (ConverterPreview.PageIndexLists.Last<int>() + 1).ToString();
  466. ConverterPreview.PageIndex.Text = ConverterPreview.PageIndexLists.Count.ToString();
  467. ConverterPreview.CurrentIndex = 0;
  468. }
  469. }
  470. private void CmbPageTextChangedEvent(object e)
  471. {
  472. var ConverterPreview = e as PageTurningPreview;
  473. if (ConverterPreview != null)
  474. {
  475. if (ConverterPreview != null)
  476. {
  477. string PageRangeSelectIndex = this.PageRangeSelectIndex;
  478. var currentViewer = this.currentViewer;
  479. string PageRange = "";
  480. var PageRangeText = this.PageRangeText;
  481. HomePageEditHelper.GetPagerange(PageRangeSelectIndex, currentViewer, ref PageRange, PageRangeText, !IsCurrentPageIndex);
  482. char[] enumerationSeparator = new char[] { ',' };
  483. char[] rangeSeparator = new char[] { '-' };
  484. if (!CommonHelper.GetPagesInRange(ref ConverterPreview.PageIndexLists, PageRange, currentViewer.Document.PageCount, enumerationSeparator, rangeSeparator))
  485. { //TODO
  486. HomePageEditHelper.GetPagerange("0", currentViewer, ref PageRange, PageRangeText, !IsCurrentPageIndex);
  487. if (!CommonHelper.GetPagesInRange(ref ConverterPreview.PageIndexLists, PageRange, currentViewer.Document.PageCount, enumerationSeparator, rangeSeparator))
  488. { //TODO
  489. ConverterPreview.PageIndexLists.Add(0);
  490. Trace.WriteLine("输入不对");
  491. AlertsMessage alertsMessage = new AlertsMessage();
  492. alertsMessage.ShowDialog("", App.MainPageLoader.GetString("PageRangeWarning"), App.ServiceLoader.GetString("Text_ok"));
  493. return;
  494. }
  495. ConverterPreview.PageIndex.Text = ConverterPreview.PageIndexLists.Count.ToString();
  496. ConverterPreview.CurrentIndex = 0;
  497. return;
  498. }
  499. else
  500. {
  501. // ConverterPreview.PageIndex.Text = (ConverterPreview.PageIndexLists.Last<int>() + 1).ToString();
  502. ConverterPreview.PageIndex.Text = ConverterPreview.PageIndexLists.Count.ToString();
  503. ConverterPreview.CurrentIndex = 0;
  504. }
  505. }
  506. }
  507. }
  508. private void BatchConverter()
  509. {
  510. DialogParameters convertpdftoword = new DialogParameters();
  511. convertpdftoword.Add(ParameterNames.BatchProcessing_Name, "0");
  512. convertpdftoword.Add("ConverterTypeIndex", 1);
  513. HomePageBatchProcessingDialogModel.FilePaths = new List<string> { currentViewer.Document.FilePath.ToString() };
  514. HomePageBatchProcessingDialogModel.BatchProcessingIndex = 1;
  515. convertpdftoword.Add(ParameterNames.FilePath, new string[] { currentViewer.Document.FilePath.ToString() });
  516. dialogs.ShowDialog(DialogNames.HomePageBatchProcessingDialog, convertpdftoword, e => { });
  517. }
  518. private void UnlockMouseDown()
  519. {
  520. ConverterHelper.convertUnlock();
  521. }
  522. private void radiobutton(string e)
  523. {
  524. string radioButton = e;
  525. if (radioButton != null)
  526. {
  527. switch (radioButton)
  528. {
  529. case "AnyContentRadioBtn":
  530. OCRIsEnable = true;
  531. AnyContent(AnyContentSelectIndex);
  532. break;
  533. case "OnlyTableRadioBtn":
  534. OnlyTable(OnlyTableSelectIndex);
  535. OCRIsEnable = false;
  536. break;
  537. case "OnlyTextRadioBtn":
  538. OCRIsEnable = true;
  539. ConverterExcelModel.Options.WorksheetOpts = WorksheetOptions.ForTheDocument;
  540. ConverterExcelModel.Options.ContentOpts = ContentOptions.OnlyText;
  541. break;
  542. default:
  543. break;
  544. }
  545. }
  546. }
  547. private void AnyContent(int SelectedIndex)
  548. {
  549. switch (SelectedIndex)
  550. {
  551. case 0:
  552. ConverterExcelModel.Options.WorksheetOpts = WorksheetOptions.ForEachPage;
  553. ConverterExcelModel.Options.ContentOpts = ContentOptions.AllContent;
  554. break;
  555. case 1:
  556. ConverterExcelModel.Options.WorksheetOpts = WorksheetOptions.ForTheDocument;
  557. ConverterExcelModel.Options.ContentOpts = ContentOptions.AllContent;
  558. break;
  559. default:
  560. break;
  561. }
  562. }
  563. private void OnlyTable(int SelectedIndex)
  564. {
  565. ConverterExcelModel.Options.ContentOpts = ContentOptions.OnlyTable;
  566. switch (SelectedIndex)
  567. {
  568. case 0:
  569. ConverterExcelModel.Options.WorksheetOpts = WorksheetOptions.ForEachTable;
  570. break;
  571. case 1:
  572. ConverterExcelModel.Options.WorksheetOpts = WorksheetOptions.ForEachPage;
  573. break;
  574. case 2:
  575. ConverterExcelModel.Options.WorksheetOpts = WorksheetOptions.ForTheDocument;
  576. break;
  577. default:
  578. break;
  579. }
  580. }
  581. private void SelectLanguage(int SelectedIndex)
  582. {
  583. switch (SelectedIndex)
  584. {
  585. case 0:
  586. ConverterExcelModel.Options.OCRLanguage = COCRLanguage.COCRLanguageChinese;
  587. break;
  588. case 1:
  589. ConverterExcelModel.Options.OCRLanguage = COCRLanguage.COCRLanguageChineseTraditional;
  590. break;
  591. case 2:
  592. ConverterExcelModel.Options.OCRLanguage = COCRLanguage.COCRLanguageEnglish;
  593. break;
  594. case 3:
  595. ConverterExcelModel.Options.OCRLanguage = COCRLanguage.COCRLanguageJapanese;
  596. break;
  597. case 4:
  598. ConverterExcelModel.Options.OCRLanguage = COCRLanguage.COCRLanguageKorean;
  599. break;
  600. default:
  601. break;
  602. }
  603. }
  604. #endregion
  605. #region 构架行为
  606. public bool CanCloseDialog()
  607. {
  608. return true;
  609. }
  610. public void OnDialogClosed()
  611. {
  612. }
  613. public void OnDialogOpened(IDialogParameters parameters)
  614. {
  615. CPDFViewer pdfViewer = null;
  616. parameters.TryGetValue<CPDFViewer>(ParameterNames.PDFViewer, out pdfViewer);
  617. parameters.TryGetValue<bool>("PageRangeComboBoxCurrentPage", out IsCurrentPageIndex);
  618. if (pdfViewer != null)
  619. {
  620. InitCheckPageSelect();
  621. currentViewer = pdfViewer;
  622. MaxPageRange = currentViewer.Document.PageCount;
  623. if (currentViewer.Tag != null) { ConverterExcelModel.Pawssword = currentViewer.Tag.ToString(); }
  624. ConverterExcelModel.InputPath = pdfViewer.Document.FilePath;
  625. FileInfo fileinfo = new FileInfo(ConverterExcelModel.InputPath);
  626. ConverterExcelModel.OutputPath = fileinfo.DirectoryName;
  627. if (Settings.Default.UserDate.subscribestatus != 1)
  628. {
  629. LimitationsConvertVisible = Visibility.Visible;
  630. }
  631. }
  632. }
  633. #endregion
  634. }
  635. }