EpsoniPrintSharedActivity.java 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437
  1. package com.epson.iprint.shared;
  2. import android.app.Activity;
  3. import android.content.Context;
  4. import android.content.Intent;
  5. import android.os.Bundle;
  6. import android.os.Handler;
  7. import android.os.Message;
  8. import androidx.appcompat.app.AppCompatActivity;
  9. import androidx.fragment.app.FragmentActivity;
  10. import com.epson.iprint.prtlogger.CommonLog;
  11. import com.epson.iprint.prtlogger.NewLoggerController;
  12. import com.epson.iprint.prtlogger.PrintLog;
  13. import com.epson.mobilephone.common.license.LicenseTopActivity;
  14. import epson.common.Constants;
  15. import epson.common.DialogProgress;
  16. import epson.common.DialogProgressViewModel;
  17. import epson.common.ExternalFileUtils;
  18. import epson.common.IprintLicenseInfo;
  19. import epson.common.IprintUserSurveyInfo;
  20. import epson.common.Utils;
  21. import epson.print.ActivityRequestPermissions;
  22. import epson.print.ActivityViewImageSelect;
  23. import epson.print.R;
  24. import epson.print.EPImageUtil;
  25. import epson.print.MyPrinter;
  26. import epson.print.Util.EPLog;
  27. import epson.print.WebviewActivity;
  28. import epson.scan.activity.ScanActivity;
  29. import java.io.File;
  30. import java.io.IOException;
  31. import java.util.ArrayList;
  32. import java.util.Deque;
  33. public class EpsoniPrintSharedActivity extends AppCompatActivity implements Runnable {
  34. public static final String ACTION_CONFIRM_PRINTER_SCANNER_SELECTION = "com.epson.iprint.isSetDevice";
  35. public static final String ACTION_PHOTO_PRINT = "com.epson.iprint.photo";
  36. public static final String ACTION_SCAN = "com.epson.iprint.scan";
  37. public static final String ACTION_WEB_PRINT = "com.epson.iprint.web";
  38. public static final String ACTIVITY_GET_PRINTER_INFORMATION = "epson.maintain.activity.GetPrinterReplyData";
  39. private static final int ACTIVITY_INTENT_PARAMETER_ERROR_ = 1;
  40. public static final String ACTIVITY_SCAN = "epson.scan.activity.ScanActivity";
  41. public static final String DIALOG_WAIT = "dialog_wait";
  42. public static final String GET_PRINTER_INFORMATION = "com.epson.iprint.status";
  43. public static final int INK_STATUS_ERROR = -1;
  44. public static final int INK_STATUS_INK_END = 2;
  45. public static final int INK_STATUS_INK_LOW = 1;
  46. public static final int INK_STATUS_NORMAL = 0;
  47. private static final int ISSETDEVICE_DEVICE_NOT_SET = 0;
  48. private static final int ISSETDEVICE_LOCAL_DEVICE_SET = -1;
  49. private static final int ISSETDEVICE_REMOTE_DEVICE_SET = -2;
  50. private static final String LOG_TAG = "iPrintSharedActivity";
  51. public static final String PACKAGE_PANASONIC_FAX = "com.panasonic.psn.fax";
  52. public static final String PARAM_KEY_CALLER_PACKAGE_NAME = "PACKAGE_NAME";
  53. private static final int REQUEST_CODE_LICENSE_CHECK = 101;
  54. private static final int REQUEST_PHOTO_CUSTOM = 10;
  55. private static final int REQUEST_RUNTIMEPERMMISSION = 100;
  56. private static final int REQUEST_SCAN_CUSTOM = 20;
  57. private static final int REQUEST_STATUS_CUSTOM = 99;
  58. private static final int REQUEST_WEB_CUSTOM = 30;
  59. public static final int RESULT_NO_SD_ERROR = 1;
  60. public static final int RESULT_PARAM_ERROR = 0;
  61. Handler mHandler = new Handler() {
  62. public void handleMessage(Message message) {
  63. if (message.what != 0) {
  64. EPLog.w(EpsoniPrintSharedActivity.LOG_TAG, "handleMessage::default");
  65. EpsoniPrintSharedActivity.this.CleanUp();
  66. return;
  67. }
  68. EPLog.i(EpsoniPrintSharedActivity.LOG_TAG, "handleMessage::0");
  69. EpsoniPrintSharedActivity.this.setWait();
  70. }
  71. };
  72. private DialogProgressViewModel mModelDialog;
  73. private Thread thread;
  74. protected void onCreate(Bundle bundle) {
  75. EPLog.i(LOG_TAG, "onCreate");
  76. super.onCreate(bundle);
  77. this.mModelDialog = (DialogProgressViewModel) ViewModelProviders.m2of((FragmentActivity) this).get(DialogProgressViewModel.class);
  78. this.mModelDialog.getDialogJob().observe(this, new Observer() {
  79. public final void onChanged(Object obj) {
  80. EpsoniPrintSharedActivity.lambda$onCreate$0(EpsoniPrintSharedActivity.this, (Deque) obj);
  81. }
  82. });
  83. NewLoggerController.stopLoggerIfNotAgreed(this);
  84. if (bundle == null) {
  85. startLicenseCheckActivity();
  86. } else if (!IprintLicenseInfo.isAgreedCurrentVersion(this)) {
  87. finish();
  88. } else {
  89. nextOnCreate();
  90. }
  91. }
  92. public static /* synthetic */ void lambda$onCreate$0(EpsoniPrintSharedActivity epsoniPrintSharedActivity, Deque deque) {
  93. String[] checkQueue = epsoniPrintSharedActivity.mModelDialog.checkQueue();
  94. if (checkQueue != null) {
  95. String str = checkQueue[0];
  96. String str2 = checkQueue[1];
  97. if (str2.equals("do_show")) {
  98. epsoniPrintSharedActivity.showDialog(str);
  99. }
  100. if (str2.equals("do_dismiss")) {
  101. epsoniPrintSharedActivity.dismissDialog(str);
  102. }
  103. }
  104. }
  105. private void startLicenseCheckActivity() {
  106. IprintLicenseInfo.beforeLicenseCheck(getApplicationContext());
  107. startActivityForResult(LicenseTopActivity.getStartIntent(getApplicationContext(), new IprintLicenseInfo(), new IprintUserSurveyInfo()), 101);
  108. }
  109. private void nextOnCreate() {
  110. Intent intent = getIntent();
  111. intent.getAction();
  112. if (intent.getExtras() != null) {
  113. try {
  114. InitTempFolder();
  115. CheckAction(intent.getAction());
  116. ManagePreferences managePreferences = new ManagePreferences();
  117. managePreferences.resetSavedFlag(getApplicationContext(), "PrintSetting");
  118. managePreferences.pushPreferrences(getApplicationContext());
  119. String action = intent.getAction();
  120. if (action.equals(GET_PRINTER_INFORMATION)) {
  121. Intent intent2 = new Intent();
  122. intent2.setClassName(getPackageName(), ACTIVITY_GET_PRINTER_INFORMATION);
  123. startActivityForResult(intent2, 99);
  124. } else if (action.equals(ACTION_CONFIRM_PRINTER_SCANNER_SELECTION)) {
  125. setPrinterScannerSelectionInfo();
  126. } else {
  127. if (!IprintLicenseInfo.isAgreedCurrentVersion(this)) {
  128. finish();
  129. }
  130. this.mHandler.sendEmptyMessage(0);
  131. }
  132. } catch (SharedDataException e) {
  133. e.printStackTrace();
  134. setResult(1);
  135. finish();
  136. } catch (IOException e2) {
  137. e2.printStackTrace();
  138. setResult(2);
  139. finish();
  140. }
  141. } else {
  142. throw new SharedDataException("bundle null error");
  143. }
  144. }
  145. private boolean CheckAction(String str) throws SharedDataException {
  146. if (str.equals(ACTION_PHOTO_PRINT) || str.equals(ACTION_SCAN) || str.equals(ACTION_WEB_PRINT) || str.equals(GET_PRINTER_INFORMATION) || str.equals(ACTION_CONFIRM_PRINTER_SCANNER_SELECTION)) {
  147. return true;
  148. }
  149. throw new SharedDataException("action error");
  150. }
  151. public void run() {
  152. EPLog.i(LOG_TAG, "run");
  153. try {
  154. Thread.sleep(100);
  155. } catch (InterruptedException unused) {
  156. }
  157. EPLog.i(LOG_TAG, "run::1");
  158. this.mHandler.sendEmptyMessage(1);
  159. }
  160. private void setWait() {
  161. this.mModelDialog.doShow(DIALOG_WAIT);
  162. this.thread = new Thread(new Runnable() {
  163. public void run() {
  164. EpsoniPrintSharedActivity.this.backgroundJob();
  165. }
  166. });
  167. try {
  168. if (ActivityRequestPermissions.isRuntimePermissionSupported() && getIntent().getAction().equals(ACTION_PHOTO_PRINT) && 4 == getIntent().getExtras().getInt("FILE_TYPE", 2)) {
  169. String[] strArr = {"android.permission.WRITE_EXTERNAL_STORAGE"};
  170. ActivityRequestPermissions.Permission permission = new ActivityRequestPermissions.Permission(strArr[0], new String[]{getString(R.string.permission_dialog_title), getString(R.string.permission_dialog_title)}, new String[]{ActivityRequestPermissions.DialogParameter.setMessage2((Context) this, getString(R.string.permission_dialog_message_storage)), ActivityRequestPermissions.DialogParameter.setMessage3A((Context) this, getString(R.string.permission_dialog_message_storage), getString(R.string.permission_function_storage))});
  171. if (!ActivityRequestPermissions.checkPermission(this, strArr)) {
  172. ActivityRequestPermissions.requestPermission((Activity) this, permission, 100);
  173. return;
  174. }
  175. }
  176. } catch (Exception e) {
  177. e.printStackTrace();
  178. }
  179. this.thread.start();
  180. }
  181. private void backgroundJob() {
  182. int i;
  183. EPLog.i(LOG_TAG, "backgroundJob");
  184. Intent intent = getIntent();
  185. if (intent == null) {
  186. setResult(1);
  187. finish();
  188. return;
  189. }
  190. Intent intent2 = new Intent();
  191. Bundle extras = intent.getExtras();
  192. if (extras == null) {
  193. setResult(1);
  194. finish();
  195. return;
  196. }
  197. try {
  198. if (intent.getAction().equals(ACTION_PHOTO_PRINT)) {
  199. SharedParamPhoto sharedParamPhoto = new SharedParamPhoto();
  200. sharedParamPhoto.setParam(extras);
  201. if (sharedParamPhoto.getPackage_name().indexOf(PACKAGE_PANASONIC_FAX) != -1) {
  202. new ManagePreferences().setPreferences(PACKAGE_PANASONIC_FAX, getApplicationContext());
  203. } else {
  204. new ManagePreferences().setPreferences(sharedParamPhoto.getMedia_type(), sharedParamPhoto.getMedia_size(), sharedParamPhoto.getColor_mode(), sharedParamPhoto.getLayout_type(), getApplicationContext());
  205. }
  206. if (sharedParamPhoto.isTIFF()) {
  207. convertTiff(sharedParamPhoto);
  208. }
  209. intent2.setClass(this, ActivityViewImageSelect.class);
  210. intent2.setAction(intent.getAction());
  211. intent2.putExtra("extParam", sharedParamPhoto);
  212. intent2.putExtra("print_log", getPhotoPrintLog(sharedParamPhoto.getPackage_name(), 4097));
  213. i = 10;
  214. } else if (intent.getAction().equals(ACTION_SCAN)) {
  215. SharedParamScan sharedParamScan = new SharedParamScan();
  216. sharedParamScan.setParam(extras);
  217. if (sharedParamScan.getPixel_main() <= 0 || sharedParamScan.getPixel_sub() <= 0 || sharedParamScan.getRes_main() <= 0 || sharedParamScan.getRes_sub() <= 0) {
  218. throw new SharedDataException("resolution or pixel error.");
  219. }
  220. intent2.setClass(this, ScanActivity.class);
  221. intent2.setAction(intent.getAction());
  222. intent2.putExtra("extParam", sharedParamScan);
  223. intent2.putExtra(ScanActivity.PARAM_KEY_SCAN_LOG, getScanLog(getCallerPackage(intent2)));
  224. i = 20;
  225. } else if (intent.getAction().equals(ACTION_WEB_PRINT)) {
  226. String charSequence = extras.getCharSequence("URL").toString();
  227. if (charSequence.length() > 0) {
  228. intent2.setClass(this, WebviewActivity.class);
  229. intent2.setAction(intent.getAction());
  230. intent2.putExtra("android.intent.extra.TEXT", charSequence);
  231. intent2.putExtra("print_log", getPhotoPrintLog(extras.getString(PARAM_KEY_CALLER_PACKAGE_NAME), PrintLog.PRINT_SOURCE_EXTERNAL_APP_WEB));
  232. i = 30;
  233. } else {
  234. throw new SharedDataException("URL error");
  235. }
  236. } else {
  237. setResult(1);
  238. finish();
  239. return;
  240. }
  241. startActivityForResult(intent2, i);
  242. this.mHandler.sendEmptyMessageDelayed(1, 500);
  243. } catch (SharedDataException e) {
  244. e.printStackTrace();
  245. setResult(1);
  246. finish();
  247. } catch (NullPointerException e2) {
  248. e2.printStackTrace();
  249. setResult(1);
  250. finish();
  251. }
  252. }
  253. private String getCallerPackage(Intent intent) {
  254. String stringExtra;
  255. if (intent == null || (stringExtra = intent.getStringExtra(PARAM_KEY_CALLER_PACKAGE_NAME)) == null) {
  256. return getCallingPackage();
  257. }
  258. return stringExtra;
  259. }
  260. private CommonLog getScanLog(String str) {
  261. CommonLog commonLog = new CommonLog();
  262. commonLog.action = PrintLog.ACTION_EXTERNAL_APP_SCAN;
  263. commonLog.callerPackage = str;
  264. return commonLog;
  265. }
  266. private PrintLog getPhotoPrintLog(String str, int i) {
  267. PrintLog printLog = new PrintLog();
  268. printLog.uiRoute = i;
  269. printLog.callerPackage = str;
  270. if (printLog.callerPackage == null) {
  271. printLog.callerPackage = getCallingPackage();
  272. }
  273. return printLog;
  274. }
  275. private int checkPrinterSelection() {
  276. if (getSharedPreferences("PrintSetting", 0).getString(Constants.PRINTER_NAME, "").length() <= 0) {
  277. return 0;
  278. }
  279. return MyPrinter.isRemotePrinter(this) ? -2 : -1;
  280. }
  281. private int checkScannerSelection() {
  282. String prefString = Utils.getPrefString(getApplicationContext(), Constants.SCAN_REFS_USED_SCANNER_PATH, Constants.SCAN_REFS_SCANNER_MODEL);
  283. return (prefString.equals(getString(R.string.str_lbl_title_scan)) || prefString.equals("")) ? 0 : -1;
  284. }
  285. private void setPrinterScannerSelectionInfo() {
  286. int i;
  287. switch (getIntent().getIntExtra("DEVICE_TYPE", -1)) {
  288. case 0:
  289. i = checkPrinterSelection();
  290. break;
  291. case 1:
  292. i = checkScannerSelection();
  293. break;
  294. default:
  295. i = 1;
  296. break;
  297. }
  298. setResult(i);
  299. finish();
  300. }
  301. private void convertTiff(SharedParamPhoto sharedParamPhoto) {
  302. EPImageUtil ePImageUtil = new EPImageUtil();
  303. ArrayList<String> arrayFileFullPath = sharedParamPhoto.getArrayFileFullPath();
  304. ArrayList<String> arrayFilePath = sharedParamPhoto.getArrayFilePath();
  305. for (int i = 0; i < arrayFilePath.size(); i++) {
  306. String tempSharedDir = ExternalFileUtils.getInstance(this).getTempSharedDir();
  307. ePImageUtil.tiff2bmp(arrayFileFullPath.get(i), new File(tempSharedDir, Utils.getPreffix(arrayFilePath.get(i)) + ".bmp").getPath());
  308. String tempSharedDir2 = ExternalFileUtils.getInstance(this).getTempSharedDir();
  309. sharedParamPhoto.setArrayFileFullPath(i, new File(tempSharedDir2, Utils.getPreffix(arrayFilePath.get(i)) + ".bmp").getPath());
  310. }
  311. }
  312. private void showDialog(String str) {
  313. DialogProgress dialogProgress;
  314. if (((str.hashCode() == 23812620 && str.equals(DIALOG_WAIT)) ? (char) 0 : 65535) != 0) {
  315. dialogProgress = null;
  316. } else {
  317. dialogProgress = DialogProgress.newInstance(str, 0, getString(R.string.str_wait));
  318. }
  319. if (dialogProgress != null) {
  320. dialogProgress.setCancelable(true);
  321. dialogProgress.show(getSupportFragmentManager(), str);
  322. }
  323. }
  324. private void dismissDialog(String str) {
  325. DialogFragment dialogFragment = (DialogFragment) getSupportFragmentManager().findFragmentByTag(str);
  326. if (dialogFragment != null) {
  327. dialogFragment.dismiss();
  328. }
  329. }
  330. protected void onActivityResult(int i, int i2, Intent intent) {
  331. super.onActivityResult(i, i2, intent);
  332. EPLog.i(LOG_TAG, "onActivityResult::requestCode = " + i + "/requestCode = " + i2);
  333. if (i == 10) {
  334. setResult(i2);
  335. } else if (i == 20) {
  336. Intent intent2 = new Intent();
  337. if (intent != null) {
  338. intent2.putExtra("FILE_NAME", ScanActivity.getScanFileListFromReturnIntent(intent));
  339. }
  340. setResult(i2, intent2);
  341. } else if (i != 30) {
  342. switch (i) {
  343. case 99:
  344. Intent intent3 = new Intent();
  345. if (intent == null) {
  346. setResult(i2);
  347. break;
  348. } else {
  349. SharedParamStatus sharedParamStatus = (SharedParamStatus) intent.getSerializableExtra("extStatus");
  350. if (sharedParamStatus == null) {
  351. setResult(i2);
  352. break;
  353. } else {
  354. intent3.putExtra(Constants.PRINTER_NAME, sharedParamStatus.getPrinter_name());
  355. intent3.putExtra("INK_NAME", sharedParamStatus.getArrayOutInkName());
  356. intent3.putExtra("INK_REMAIN", sharedParamStatus.getArrayOutInkRemain());
  357. intent3.putExtra("STATUS_VALUE", sharedParamStatus.getPrinter_status());
  358. intent3.putExtra("DEVICE_ID", sharedParamStatus.getPrinter_name());
  359. intent3.putExtra("INK_STATUS", sharedParamStatus.getExternInkStatus());
  360. setResult(i2, intent3);
  361. break;
  362. }
  363. }
  364. case 100:
  365. if (i2 == -1) {
  366. this.thread.start();
  367. break;
  368. } else {
  369. setResult(0);
  370. finish();
  371. break;
  372. }
  373. case 101:
  374. if (i2 != -1) {
  375. finish();
  376. return;
  377. } else {
  378. nextOnCreate();
  379. return;
  380. }
  381. }
  382. } else {
  383. setResult(i2);
  384. }
  385. finish();
  386. }
  387. protected void onDestroy() {
  388. super.onDestroy();
  389. ManagePreferences managePreferences = new ManagePreferences();
  390. if (managePreferences.getSavedFlag(getApplicationContext(), "PrintSetting") == 0) {
  391. EPLog.i(LOG_TAG, "Preference 戻す");
  392. managePreferences.popPreferrences(getApplicationContext());
  393. }
  394. CleanUp();
  395. try {
  396. InitTempFolder();
  397. } catch (IOException unused) {
  398. }
  399. }
  400. private void CleanUp() {
  401. Thread thread2 = this.thread;
  402. if (thread2 != null && thread2.isAlive()) {
  403. this.thread.interrupt();
  404. this.thread = null;
  405. }
  406. this.mModelDialog.doDismiss(DIALOG_WAIT);
  407. }
  408. private void InitTempFolder() throws IOException {
  409. ExternalFileUtils.getInstance(this).initTempSharedDir();
  410. }
  411. }