ConverterExcelDialogViewModel.cs 28 KB

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