MemcardImageGrid.java 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716
  1. package com.epson.memcardacc;
  2. import android.annotation.SuppressLint;
  3. import android.annotation.TargetApi;
  4. import android.arch.lifecycle.Observer;
  5. import android.arch.lifecycle.ViewModelProviders;
  6. import android.content.Intent;
  7. import android.graphics.Bitmap;
  8. import android.os.AsyncTask;
  9. import android.os.Build;
  10. import android.os.Bundle;
  11. import android.os.Handler;
  12. import android.os.Message;
  13. import android.view.Menu;
  14. import android.view.MenuItem;
  15. import android.view.View;
  16. import android.view.ViewTreeObserver;
  17. import android.widget.AdapterView;
  18. import android.widget.GridView;
  19. import android.widget.ProgressBar;
  20. import android.widget.TextView;
  21. import com.epson.memcardacc.ImageFileListAdapter;
  22. import com.epson.memcardacc.MemcardTempAlertDialog;
  23. import com.epson.mobilephone.common.wifidirect.WiFiDirectManager;
  24. import epson.common.DialogProgress;
  25. import epson.common.DialogProgressViewModel;
  26. import epson.print.ActivityIACommon;
  27. import epson.print.Util.EPLog;
  28. import java.io.UnsupportedEncodingException;
  29. import java.util.Deque;
  30. import java.util.Iterator;
  31. import java.util.LinkedList;
  32. import java.util.Locale;
  33. import java.util.concurrent.LinkedBlockingQueue;
  34. public class MemcardImageGrid extends ActivityIACommon implements DialogProgress.DialogButtonClick {
  35. static final int ACTIVITY_TYPE_CONFIRM_COPY = 1;
  36. private static final String DIALOG_FILE_READ_ERROR = "dialog_file_read_error";
  37. private static final String DIALOG_NO_IMAGE_SELECTED = "dialog_no_image_selected";
  38. private static final String DIALOG_OVER_SELECTED_NUMBER = "dialog_over_selected_number";
  39. private static final String DIALOG_PROGRESS = "dialog_progress";
  40. private static final String LOG_TAG = "MemcardImageGrid";
  41. public static final String MEMCARD_STORAGE_TYPE = "memcard_storage_type";
  42. static final int MESSAGE_EXEC_NEXT_TASK_OR_IDLE = 2;
  43. static final int MESSAGE_WAIT_TASK_FINISHED_AND_NEXT_TASK = 1;
  44. static final long NEXT_TASK_WAITE = 300;
  45. public static final int RESULT_BACK_TO_MEMCARD_TOP = 1;
  46. protected static final long TASK_WAITE_PRIOD = 1000;
  47. boolean discconectOnThreadFinish = false;
  48. private boolean isFinishRequested;
  49. boolean isKeepSimleApConnect = false;
  50. boolean isTryConnectSimpleAp = false;
  51. private MemcardBitmapCache mBitmapCache;
  52. private CifsAccess mCifsAccess;
  53. private CifsFileListLoader mCifsFileListLoader;
  54. private DirectoryCache mDirectoryCache;
  55. private GridView mGridView;
  56. /* access modifiers changed from: private */
  57. @SuppressLint({"HandlerLeak"})
  58. public Handler mHandler = new Handler() {
  59. public void handleMessage(Message message) {
  60. switch (message.what) {
  61. case 1:
  62. if (MemcardImageGrid.mCifsFileListLoader != null) {
  63. EPLog.m313i(MemcardImageGrid.LOG_TAG, "status :" + MemcardImageGrid.mCifsFileListLoader.getStatus());
  64. switch (C09864.$SwitchMap$android$os$AsyncTask$Status[MemcardImageGrid.mCifsFileListLoader.getStatus().ordinal()]) {
  65. case 1:
  66. case 2:
  67. MemcardImageGrid.mHandler.sendEmptyMessageDelayed(1, 1000);
  68. return;
  69. case 3:
  70. break;
  71. default:
  72. EPLog.m307e(MemcardImageGrid.LOG_TAG, "unkown AsyncTask.getStatus() value");
  73. return;
  74. }
  75. } else {
  76. EPLog.m313i(MemcardImageGrid.LOG_TAG, "mCifsFileListLoader == null");
  77. }
  78. MemcardImageGrid.mHandler.sendEmptyMessageDelayed(2, 300);
  79. return;
  80. case 2:
  81. MemcardImageGrid.this.execNextTaskOrIdle();
  82. return;
  83. default:
  84. return;
  85. }
  86. }
  87. };
  88. private ImageFileListAdapter mImageFileListAdapter;
  89. private int mMemcardStorageType;
  90. private DialogProgressViewModel mModelDialog;
  91. private ProgressBar mProgressBar;
  92. private TextView mSelectedFileNumText;
  93. public boolean mStartDirectory;
  94. private LinkedBlockingQueue<String> mTaskQueue = new LinkedBlockingQueue<>();
  95. private int mThumbnailHeight;
  96. private int mThumbnailWidth;
  97. private String targetDir = null;
  98. public void onCancelDialog(String str) {
  99. }
  100. public void onNeutralClick(String str) {
  101. }
  102. protected void onCreate(Bundle bundle) {
  103. mBitmapCache = MemcardBitmapCache.getInstance(this);
  104. MemcardBitmapCache memcardBitmapCache = mBitmapCache;
  105. if (memcardBitmapCache == null || !memcardBitmapCache.checkEnv()) {
  106. new MemcardTempAlertDialog().showAlertDialog(this, new MemcardTempAlertDialog.DialogCallback() {
  107. public void onPositiveCallback() {
  108. MemcardImageGrid.this.finish();
  109. }
  110. });
  111. }
  112. mCifsAccess = CifsAccess.getInstance();
  113. mDirectoryCache = new DirectoryCache();
  114. mDirectoryCache.setCifsAccess(mCifsAccess);
  115. super.onCreate(bundle);
  116. mImageFileListAdapter = new ImageFileListAdapter();
  117. mImageFileListAdapter.setLayoutInflater(getLayoutInflater());
  118. mImageFileListAdapter.setUpFolderString(getResources().getString(R.string.memcard_folder_up));
  119. setContentView(R.layout.activity_memcard_image_grid);
  120. setActionBar("", true);
  121. mGridView = (GridView) findViewById(R.id.gridView1);
  122. mGridView.setAdapter(mImageFileListAdapter);
  123. mSelectedFileNumText = (TextView) findViewById(R.id.textSelectedImageNum);
  124. mGridView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
  125. public void onItemClick(AdapterView<?> adapterView, View view, int i, long j) {
  126. MemcardImageGrid.this.gridViewItemClicked(adapterView, view, i, j);
  127. }
  128. });
  129. mThumbnailWidth = getResources().getDimensionPixelSize(R.dimen.image_selector_grid_thumbnail_size);
  130. int i = mThumbnailWidth;
  131. mThumbnailHeight = i;
  132. mBitmapCache.setSize(i, mThumbnailHeight);
  133. mImageFileListAdapter.setImageSize(mThumbnailWidth, mThumbnailHeight);
  134. mGridView.getViewTreeObserver().addOnGlobalLayoutListener(new MyGridLayoutListener(mGridView, mImageFileListAdapter, getResources().getDimensionPixelSize(R.dimen.image_selector_grid_thumbnail_spacing)));
  135. updateSelectedNumber();
  136. mProgressBar = (ProgressBar) findViewById(R.id.progressBar1);
  137. mProgressBar.setVisibility(4);
  138. mMemcardStorageType = getIntent().getIntExtra("memcard_storage_type", 1);
  139. if (mMemcardStorageType <= 0) {
  140. mMemcardStorageType = 1;
  141. }
  142. mStartDirectory = true;
  143. targetDir = MemcardConfig.INIT_CIFS_DIRECTORY;
  144. mModelDialog = (DialogProgressViewModel) ViewModelProviders.m2of((FragmentActivity) this).get(DialogProgressViewModel.class);
  145. mModelDialog.getDialogJob().observe(this, new Observer() {
  146. public final void onChanged(Object obj) {
  147. MemcardImageGrid.lambda$onCreate$0(MemcardImageGrid.this, (Deque) obj);
  148. }
  149. });
  150. }
  151. public static /* synthetic */ void lambda$onCreate$0(MemcardImageGrid memcardImageGrid, Deque deque) {
  152. String[] checkQueue = memcardImageGrid.mModelDialog.checkQueue();
  153. if (checkQueue != null) {
  154. String str = checkQueue[0];
  155. String str2 = checkQueue[1];
  156. if (str2.equals("do_show")) {
  157. memcardImageGrid.showDialog(str);
  158. }
  159. if (str2.equals("do_dismiss")) {
  160. memcardImageGrid.dismissDialog(str);
  161. }
  162. }
  163. }
  164. private void dispTargetDirectory() {
  165. setTitle(mImageFileListAdapter.getTargetDirectoryName());
  166. }
  167. protected void onStop() {
  168. mHandler.removeMessages(1);
  169. if (!this.isKeepSimleApConnect) {
  170. CifsFileListLoader cifsFileListLoader = mCifsFileListLoader;
  171. if (cifsFileListLoader != null && cifsFileListLoader.getStatus() == AsyncTask.Status.RUNNING) {
  172. discconectOnThreadFinish = true;
  173. }
  174. if (!this.discconectOnThreadFinish) {
  175. EPLog.m305d(LOG_TAG, "discconect at onStop()");
  176. WiFiDirectManager.disconnect(this, WiFiDirectManager.DEVICE_TYPE_PRINTER, MemcardUtil.getPrinterIpAddress(this));
  177. }
  178. }
  179. cancelFileListLoadTask();
  180. super.onStop();
  181. }
  182. protected void onRestart() {
  183. super.onRestart();
  184. targetDir = mImageFileListAdapter.getTargetDirectoryName();
  185. }
  186. protected void onResume() {
  187. super.onResume();
  188. if (!WiFiDirectManager.isNeedConnect(this, WiFiDirectManager.DEVICE_TYPE_PRINTER)) {
  189. isTryConnectSimpleAp = false;
  190. } else if (!this.isTryConnectSimpleAp) {
  191. isTryConnectSimpleAp = true;
  192. if (WiFiDirectManager.reconnect(this, WiFiDirectManager.DEVICE_TYPE_PRINTER, -1)) {
  193. return;
  194. }
  195. }
  196. isKeepSimleApConnect = false;
  197. discconectOnThreadFinish = false;
  198. if (!this.isFinishRequested) {
  199. chengeTargetDirectory(this.targetDir);
  200. }
  201. }
  202. protected void onActivityResult(int i, int i2, Intent intent) {
  203. super.onActivityResult(i, i2, intent);
  204. if (i2 == 1 && i2 == 1) {
  205. setResult(1);
  206. finishMemCardImageGridActivity();
  207. }
  208. }
  209. private void gridViewItemClicked(AdapterView<?> adapterView, View view, int i, long j) {
  210. String directoryName = mImageFileListAdapter.getDirectoryName(i);
  211. if (directoryName != null) {
  212. EPLog.m313i(LOG_TAG, "item clicked : dir_name => " + directoryName);
  213. chengeTargetDirectory(directoryName);
  214. } else if (mImageFileListAdapter.itemSelected(i)) {
  215. updateSelectedNumber();
  216. } else {
  217. localShowDialog(DIALOG_OVER_SELECTED_NUMBER);
  218. }
  219. }
  220. public boolean onCreateOptionsMenu(Menu menu) {
  221. int selectedFileNum = mImageFileListAdapter.getSelectedFileNum();
  222. getMenuInflater().inflate(R.menu.menu_image_selector, menu);
  223. menu.findItem(R.id.action_go_preview).setEnabled(selectedFileNum > 0);
  224. if (selectedFileNum <= 0) {
  225. setTitle(mImageFileListAdapter.getTargetDirectoryName());
  226. } else {
  227. setTitle(String.format(getResources().getString(R.string.photo_selected), new Object[]{Integer.valueOf(selectedFileNum)}));
  228. }
  229. return true;
  230. }
  231. public boolean onOptionsItemSelected(MenuItem menuItem) {
  232. if (menuItem.getItemId() != R.id.action_go_preview) {
  233. return super.onOptionsItemSelected(menuItem);
  234. }
  235. goNext();
  236. return true;
  237. }
  238. public void updateSelectedNumber() {
  239. supportInvalidateOptionsMenu();
  240. }
  241. public void next_button_clicked(View view) {
  242. goNext();
  243. }
  244. private void goNext() {
  245. showProgressDialog();
  246. if (mImageFileListAdapter.getSelectedFileNum() <= 0) {
  247. dismissProgressDialog();
  248. localShowDialog(DIALOG_NO_IMAGE_SELECTED);
  249. return;
  250. }
  251. cancelFileListLoadTask();
  252. Intent intent = new Intent(this, ConfirmReadMemcard.class);
  253. intent.putStringArrayListExtra(ConfirmReadMemcard.KEY_IMAGE_LIST, mImageFileListAdapter.getAllSelectedFile());
  254. intent.putExtra("memcard_storage_type", mMemcardStorageType);
  255. startActivityForResult(intent, 1);
  256. dismissProgressDialog();
  257. isKeepSimleApConnect = true;
  258. }
  259. public void onBackPressed() {
  260. finishMemCardImageGridActivity();
  261. }
  262. private void finishMemCardImageGridActivity() {
  263. mHandler.removeMessages(1);
  264. cancelFileListLoadTask();
  265. finish();
  266. isFinishRequested = true;
  267. }
  268. private void localShowDialog(String str) {
  269. mModelDialog.doShow(str);
  270. }
  271. private void chengeTargetDirectory(String str) {
  272. EPLog.m313i(LOG_TAG, "chengeTargetDirectory() start");
  273. showProgressDialog();
  274. mTaskQueue.clear();
  275. cancelFileListLoadTask();
  276. try {
  277. mTaskQueue.put(str);
  278. mHandler.sendEmptyMessage(1);
  279. } catch (InterruptedException e) {
  280. e.printStackTrace();
  281. EPLog.m307e(LOG_TAG, "queue.put() error in chengeTargetDirectory()");
  282. dismissProgressDialog();
  283. }
  284. }
  285. protected void execNextTaskOrIdle() {
  286. if (!mTaskQueue.isEmpty()) {
  287. EPLog.m313i(LOG_TAG, "checkQueue() queue not empty");
  288. mCifsFileListLoader = new CifsFileListLoader();
  289. String str = "";
  290. while (!mTaskQueue.isEmpty()) {
  291. str = mTaskQueue.poll();
  292. }
  293. mCifsFileListLoader.execute(new String[]{str});
  294. return;
  295. }
  296. dismissProgressDialog();
  297. }
  298. private void cancelFileListLoadTask() {
  299. CifsFileListLoader cifsFileListLoader = mCifsFileListLoader;
  300. if (cifsFileListLoader != null) {
  301. cifsFileListLoader.cancelTask();
  302. }
  303. }
  304. private void showProgressDialog() {
  305. mModelDialog.doShow(DIALOG_PROGRESS);
  306. }
  307. private void dismissProgressDialog() {
  308. mModelDialog.doDismiss(DIALOG_PROGRESS);
  309. }
  310. /* JADX WARNING: Removed duplicated region for block: B:23:0x0049 */
  311. /* JADX WARNING: Removed duplicated region for block: B:24:0x004b */
  312. /* JADX WARNING: Removed duplicated region for block: B:25:0x0069 */
  313. /* JADX WARNING: Removed duplicated region for block: B:26:0x0084 */
  314. /* JADX WARNING: Removed duplicated region for block: B:27:0x0099 */
  315. /* JADX WARNING: Removed duplicated region for block: B:29:0x00ad */
  316. /* JADX WARNING: Removed duplicated region for block: B:31:? A[RETURN, SYNTHETIC] */
  317. /* Code decompiled incorrectly, please refer to instructions dump. */
  318. private void showDialog(java.lang.String r11) {
  319. /*
  320. r10 = this;
  321. int r0 = r11.hashCode()
  322. r1 = -903480314(0xffffffffca25fc06, float:-2719489.5)
  323. r2 = 0
  324. if (r0 == r1) goto L_0x0038
  325. r1 = -842795367(0xffffffffcdc3f699, float:-4.10964768E8)
  326. if (r0 == r1) goto L_0x002e
  327. r1 = -195189813(0xfffffffff45da3cb, float:-7.024046E31)
  328. if (r0 == r1) goto L_0x0024
  329. r1 = -21731516(0xfffffffffeb46744, float:-1.1989861E38)
  330. if (r0 == r1) goto L_0x001a
  331. goto L_0x0042
  332. L_0x001a:
  333. java.lang.String r0 = "dialog_progress"
  334. boolean r0 = r11.equals(r0)
  335. if (r0 == 0) goto L_0x0042
  336. r0 = 0
  337. goto L_0x0043
  338. L_0x0024:
  339. java.lang.String r0 = "dialog_file_read_error"
  340. boolean r0 = r11.equals(r0)
  341. if (r0 == 0) goto L_0x0042
  342. r0 = 3
  343. goto L_0x0043
  344. L_0x002e:
  345. java.lang.String r0 = "dialog_over_selected_number"
  346. boolean r0 = r11.equals(r0)
  347. if (r0 == 0) goto L_0x0042
  348. r0 = 1
  349. goto L_0x0043
  350. L_0x0038:
  351. java.lang.String r0 = "dialog_no_image_selected"
  352. boolean r0 = r11.equals(r0)
  353. if (r0 == 0) goto L_0x0042
  354. r0 = 2
  355. goto L_0x0043
  356. L_0x0042:
  357. r0 = -1
  358. L_0x0043:
  359. r1 = 2131625202(0x7f0e04f2, float:1.8877605E38)
  360. switch(r0) {
  361. case 0: goto L_0x0099;
  362. case 1: goto L_0x0084;
  363. case 2: goto L_0x0069;
  364. case 3: goto L_0x004b;
  365. default: goto L_0x0049;
  366. }
  367. L_0x0049:
  368. r0 = 0
  369. goto L_0x00ab
  370. L_0x004b:
  371. r4 = 2
  372. r0 = 2131624887(0x7f0e03b7, float:1.8876966E38)
  373. java.lang.String r5 = r10.getString(r0)
  374. r6 = 0
  375. r0 = 2131625078(0x7f0e0476, float:1.8877354E38)
  376. java.lang.String r7 = r10.getString(r0)
  377. r8 = 0
  378. r0 = 2131625211(0x7f0e04fb, float:1.8877624E38)
  379. java.lang.String r9 = r10.getString(r0)
  380. r3 = r11
  381. epson.common.DialogProgress r0 = epson.common.DialogProgress.newInstance(r3, r4, r5, r6, r7, r8, r9)
  382. goto L_0x00ab
  383. L_0x0069:
  384. r2 = 2
  385. r0 = 2131624905(0x7f0e03c9, float:1.8877003E38)
  386. java.lang.String r3 = r10.getString(r0)
  387. r0 = 2131624906(0x7f0e03ca, float:1.8877005E38)
  388. java.lang.String r4 = r10.getString(r0)
  389. java.lang.String r5 = r10.getString(r1)
  390. r6 = 0
  391. r7 = 0
  392. r1 = r11
  393. epson.common.DialogProgress r0 = epson.common.DialogProgress.newInstance(r1, r2, r3, r4, r5, r6, r7)
  394. goto L_0x00ab
  395. L_0x0084:
  396. r2 = 2
  397. r0 = 2131624871(0x7f0e03a7, float:1.8876934E38)
  398. java.lang.String r3 = r10.getString(r0)
  399. r4 = 0
  400. r5 = 0
  401. r6 = 0
  402. java.lang.String r7 = r10.getString(r1)
  403. r1 = r11
  404. epson.common.DialogProgress r0 = epson.common.DialogProgress.newInstance(r1, r2, r3, r4, r5, r6, r7)
  405. goto L_0x00ab
  406. L_0x0099:
  407. android.content.res.Resources r0 = r10.getResources()
  408. r1 = 2131624888(0x7f0e03b8, float:1.8876968E38)
  409. java.lang.String r0 = r0.getString(r1)
  410. epson.common.DialogProgress r0 = epson.common.DialogProgress.newInstance(r11, r2, r0)
  411. r0.setCancelable(r2)
  412. L_0x00ab:
  413. if (r0 == 0) goto L_0x00b4
  414. android.support.v4.app.FragmentManager r1 = r10.getSupportFragmentManager()
  415. r0.show(r1, r11)
  416. L_0x00b4:
  417. return
  418. */
  419. throw new UnsupportedOperationException("Method not decompiled: com.epson.memcardacc.MemcardImageGrid.showDialog(java.lang.String):void");
  420. }
  421. private void dismissDialog(String str) {
  422. DialogFragment dialogFragment = (DialogFragment) getSupportFragmentManager().findFragmentByTag(str);
  423. if (dialogFragment != null) {
  424. dialogFragment.dismiss();
  425. }
  426. }
  427. /* renamed from: com.epson.memcardacc.MemcardImageGrid$4 */
  428. static /* synthetic */ class C09864 {
  429. static final /* synthetic */ int[] $SwitchMap$android$os$AsyncTask$Status = new int[AsyncTask.Status.values().length];
  430. /* JADX WARNING: Can't wrap try/catch for region: R(8:0|1|2|3|4|5|6|8) */
  431. /* JADX WARNING: Failed to process nested try/catch */
  432. /* JADX WARNING: Missing exception handler attribute for start block: B:3:0x0014 */
  433. /* JADX WARNING: Missing exception handler attribute for start block: B:5:0x001f */
  434. static {
  435. /*
  436. android.os.AsyncTask$Status[] r0 = android.os.AsyncTask.Status.values()
  437. int r0 = r0.length
  438. int[] r0 = new int[r0]
  439. $SwitchMap$android$os$AsyncTask$Status = r0
  440. int[] r0 = $SwitchMap$android$os$AsyncTask$Status // Catch:{ NoSuchFieldError -> 0x0014 }
  441. android.os.AsyncTask$Status r1 = android.os.AsyncTask.Status.PENDING // Catch:{ NoSuchFieldError -> 0x0014 }
  442. int r1 = r1.ordinal() // Catch:{ NoSuchFieldError -> 0x0014 }
  443. r2 = 1
  444. r0[r1] = r2 // Catch:{ NoSuchFieldError -> 0x0014 }
  445. L_0x0014:
  446. int[] r0 = $SwitchMap$android$os$AsyncTask$Status // Catch:{ NoSuchFieldError -> 0x001f }
  447. android.os.AsyncTask$Status r1 = android.os.AsyncTask.Status.RUNNING // Catch:{ NoSuchFieldError -> 0x001f }
  448. int r1 = r1.ordinal() // Catch:{ NoSuchFieldError -> 0x001f }
  449. r2 = 2
  450. r0[r1] = r2 // Catch:{ NoSuchFieldError -> 0x001f }
  451. L_0x001f:
  452. int[] r0 = $SwitchMap$android$os$AsyncTask$Status // Catch:{ NoSuchFieldError -> 0x002a }
  453. android.os.AsyncTask$Status r1 = android.os.AsyncTask.Status.FINISHED // Catch:{ NoSuchFieldError -> 0x002a }
  454. int r1 = r1.ordinal() // Catch:{ NoSuchFieldError -> 0x002a }
  455. r2 = 3
  456. r0[r1] = r2 // Catch:{ NoSuchFieldError -> 0x002a }
  457. L_0x002a:
  458. return
  459. */
  460. throw new UnsupportedOperationException("Method not decompiled: com.epson.memcardacc.MemcardImageGrid.C09864.<clinit>():void");
  461. }
  462. }
  463. private void selectFileList(LinkedList<CifsFileInfo> linkedList) {
  464. Iterator it = linkedList.iterator();
  465. while (it.hasNext()) {
  466. CifsFileInfo cifsFileInfo = (CifsFileInfo) it.next();
  467. if (!cifsFileInfo.isReadable() || (!cifsFileInfo.isDirectory() && !hasExtensionJpg(cifsFileInfo.mFileName))) {
  468. it.remove();
  469. }
  470. }
  471. }
  472. private boolean hasExtensionJpg(String str) {
  473. return Boolean.valueOf(str.toLowerCase(Locale.US).endsWith(".jpg")).booleanValue();
  474. }
  475. public void onPositiveClick(String str) {
  476. if (((str.hashCode() == -195189813 && str.equals(DIALOG_FILE_READ_ERROR)) ? (char) 0 : 65535) == 0) {
  477. finishMemCardImageGridActivity();
  478. }
  479. }
  480. public void onNegativeClick(String str) {
  481. if (((str.hashCode() == -195189813 && str.equals(DIALOG_FILE_READ_ERROR)) ? (char) 0 : 65535) == 0) {
  482. mStartDirectory = true;
  483. chengeTargetDirectory(MemcardConfig.INIT_CIFS_DIRECTORY);
  484. }
  485. }
  486. private static class MyGridLayoutListener implements ViewTreeObserver.OnGlobalLayoutListener {
  487. ImageFileListAdapter mAdapter;
  488. private GridView mGridView;
  489. private int mHorizontalSpacing;
  490. public MyGridLayoutListener(GridView gridView, ImageFileListAdapter imageFileListAdapter, int i) {
  491. mGridView = gridView;
  492. mAdapter = imageFileListAdapter;
  493. mHorizontalSpacing = i;
  494. }
  495. @TargetApi(16)
  496. public void onGlobalLayout() {
  497. int numColumns = mGridView.getNumColumns();
  498. if (numColumns <= 0) {
  499. return;
  500. }
  501. if (Build.VERSION.SDK_INT >= 16) {
  502. setNewVerticalParams();
  503. mGridView.getViewTreeObserver().removeOnGlobalLayoutListener(this);
  504. return;
  505. }
  506. int width = mGridView.getWidth();
  507. int i = mHorizontalSpacing;
  508. int i2 = ((width + i) / numColumns) - i;
  509. mAdapter.setImageSize(i2, i2);
  510. mGridView.getViewTreeObserver().removeGlobalOnLayoutListener(this);
  511. }
  512. @TargetApi(16)
  513. private void setNewVerticalParams() {
  514. mGridView.setVerticalSpacing(mGridView.getHorizontalSpacing());
  515. int columnWidth = mGridView.getColumnWidth();
  516. mAdapter.setImageSize(columnWidth, columnWidth);
  517. }
  518. }
  519. class CifsFileListLoader extends AsyncTask<String, Integer, Integer> {
  520. private static final int PROGRESS_UPDATE_DIRCTORY = 1;
  521. private static final int PROGRESS_UPDATE_THUMBNAIL = 2;
  522. private static final int RESULT_FILE_LIST_CANNOT_GET = 1;
  523. private static final int RESULT_OK = 0;
  524. boolean mAdapterUpdateWaitDone;
  525. String mBaseDir;
  526. boolean mCanceling;
  527. LinkedList<CifsFileInfo> mFileList;
  528. CifsFileListLoader() {
  529. }
  530. protected void onPreExecute() {
  531. EPLog.m313i(MemcardImageGrid.LOG_TAG, "doInBackground() onPreExecute().");
  532. }
  533. private boolean waiteAdapterUpdateAndCancelCheck() {
  534. if (mCanceling) {
  535. return false;
  536. }
  537. while (!mAdapterUpdateWaitDone) {
  538. try {
  539. Thread.sleep(200);
  540. if (mCanceling) {
  541. return false;
  542. }
  543. } catch (InterruptedException unused) {
  544. return false;
  545. }
  546. }
  547. return true;
  548. }
  549. protected synchronized Integer doInBackground(String... strArr) {
  550. EPLog.m313i(MemcardImageGrid.LOG_TAG, "doInBackground() started");
  551. if (MemcardImageGrid.mCifsAccess.initDefault(MemcardImageGrid.this, 1) == 0) {
  552. return null;
  553. }
  554. if (MemcardImageGrid.mCifsAccess.connectDefaultStorageWidthDefaultAthInfo(MemcardImageGrid.mMemcardStorageType) == 0) {
  555. MemcardImageGrid.mCifsAccess.free();
  556. return null;
  557. }
  558. try {
  559. String str = strArr[0];
  560. LinkedList<CifsFileInfo> fileList = MemcardImageGrid.mDirectoryCache.getFileList(str);
  561. if (fileList == null) {
  562. if (MemcardImageGrid.mStartDirectory) {
  563. str = "";
  564. fileList = MemcardImageGrid.mDirectoryCache.getFileList(str);
  565. if (fileList == null) {
  566. if (MemcardImageGrid.mCifsAccess.getFreeUnit() < 0) {
  567. MemcardImageGrid.mCifsAccess.disconnectStorage();
  568. MemcardImageGrid.mCifsAccess.free();
  569. return 1;
  570. }
  571. fileList = new LinkedList<>();
  572. }
  573. } else {
  574. fileList = new LinkedList<>();
  575. }
  576. }
  577. MemcardImageGrid.mStartDirectory = false;
  578. MemcardImageGrid.this.selectFileList(fileList);
  579. mBaseDir = str;
  580. mFileList = fileList;
  581. mAdapterUpdateWaitDone = false;
  582. publishProgress(new Integer[]{1});
  583. if (waiteAdapterUpdateAndCancelCheck()) {
  584. EPLog.m313i(MemcardImageGrid.LOG_TAG, "doInBackground() next createThumbnail");
  585. createThumbnail(MemcardImageGrid.mCifsAccess);
  586. }
  587. EPLog.m313i(MemcardImageGrid.LOG_TAG, "doInBackground() disconnectStorage()");
  588. MemcardImageGrid.mCifsAccess.disconnectStorage();
  589. if (MemcardImageGrid.this.discconectOnThreadFinish) {
  590. EPLog.m305d(MemcardImageGrid.LOG_TAG, "disconnectOnThreadFinish");
  591. WiFiDirectManager.disconnect(MemcardImageGrid.this, WiFiDirectManager.DEVICE_TYPE_PRINTER, MemcardUtil.getPrinterIpAddress(MemcardImageGrid.this));
  592. }
  593. EPLog.m313i(MemcardImageGrid.LOG_TAG, "doInBackground() end");
  594. MemcardImageGrid.mCifsAccess.free();
  595. return 0;
  596. } catch (UnsupportedEncodingException e) {
  597. try {
  598. e.printStackTrace();
  599. EPLog.m313i(MemcardImageGrid.LOG_TAG, "exception in doInBackground()");
  600. return null;
  601. } finally {
  602. MemcardImageGrid.mCifsAccess.free();
  603. }
  604. }
  605. }
  606. public void cancelTask() {
  607. if (!mCanceling) {
  608. EPLog.m313i(MemcardImageGrid.LOG_TAG, "task canceling...");
  609. mCanceling = true;
  610. MemcardImageGrid.mCifsAccess.cancel();
  611. }
  612. }
  613. protected void onProgressUpdate(Integer... numArr) {
  614. if (numArr[0].intValue() == 1) {
  615. MemcardImageGrid.mImageFileListAdapter.setFileList(mBaseDir, mFileList);
  616. MemcardImageGrid.mImageFileListAdapter.notifyDataSetChanged();
  617. mAdapterUpdateWaitDone = true;
  618. MemcardImageGrid.this.updateSelectedNumber();
  619. MemcardImageGrid.this.dismissProgressDialog();
  620. return;
  621. }
  622. MemcardImageGrid.mImageFileListAdapter.notifyDataSetChanged();
  623. }
  624. protected void onPostExecute(Integer num) {
  625. EPLog.m313i(MemcardImageGrid.LOG_TAG, "doInBackground() done.");
  626. if (num == null) {
  627. MemcardImageGrid.this.dismissProgressDialog();
  628. MemcardImageGrid.this.localShowDialog(MemcardImageGrid.DIALOG_FILE_READ_ERROR);
  629. return;
  630. }
  631. switch (num.intValue()) {
  632. case 0:
  633. MemcardImageGrid.mImageFileListAdapter.notifyDataSetChanged();
  634. return;
  635. case 1:
  636. MemcardImageGrid.this.localShowDialog(MemcardImageGrid.DIALOG_FILE_READ_ERROR);
  637. return;
  638. default:
  639. return;
  640. }
  641. }
  642. private int createThumbnail(CifsAccess cifsAccess) throws UnsupportedEncodingException {
  643. MemcardImageGrid.mBitmapCache.setCifsAccess(cifsAccess);
  644. Iterator<ImageFileListAdapter.FileInfoWithCheck> fileInfoIterator = MemcardImageGrid.mImageFileListAdapter.getFileInfoIterator();
  645. while (fileInfoIterator.hasNext()) {
  646. if (mCanceling) {
  647. return 0;
  648. }
  649. ImageFileListAdapter.FileInfoWithCheck next = fileInfoIterator.next();
  650. if (next.needThumbNail()) {
  651. if (next.isDirectory()) {
  652. next.setThumbNail((Bitmap) null);
  653. } else {
  654. String fileName = next.getFileName();
  655. EPLog.m313i(MemcardImageGrid.LOG_TAG, "name <" + fileName + ">");
  656. next.setThumbNail(MemcardImageGrid.mBitmapCache.cacheOrMakeThumbnailBitmap(fileName, next.getFullPath()));
  657. }
  658. publishProgress(new Integer[]{2});
  659. }
  660. }
  661. return 1;
  662. }
  663. }
  664. }