1
0
Fork 0
mirror of https://github.com/geometer/FBReaderJ.git synced 2025-10-04 10:19:33 +02:00

more androidish way for disabled icons; use selected path

This commit is contained in:
Nikolay Pultsin 2014-08-28 19:30:30 +01:00
parent 5328375941
commit cea22e0d6d
12 changed files with 44 additions and 20 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 507 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 683 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

View file

@ -0,0 +1,14 @@
<?xml version="1.0" encoding="utf-8"?>
<!--
Copyright (c) 2012 Hai Bison
See the file LICENSE at the root directory of this project for copying
permission.
-->
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/afc_folder_disabled" android:state_enabled="false"/> <!-- enabled -->
<item android:drawable="@drawable/afc_folder"/> <!-- default -->
</selector>

View file

@ -24,7 +24,7 @@ import java.util.Collection;
import java.util.List;
import android.content.Context;
import android.graphics.*;
import android.graphics.Paint;
import android.preference.PreferenceActivity;
import android.preference.PreferenceFragment;
import android.view.LayoutInflater;
@ -288,18 +288,8 @@ public class IFileAdapter extends BaseAdapter {
*/
bag.mTxtFileName.setSingleLine(parent instanceof GridView);
final boolean isAccessible = FileUtils.isAccessible(file, mFilenameRegexp);
// file icon
bag.mImageIcon.setImageResource(FileUtils.getResIcon(file, mFilterMode));
final ColorMatrix matrix = new ColorMatrix();
if (!isAccessible) {
final ColorMatrix scaleMatrix = new ColorMatrix();
scaleMatrix.setScale(.7f, .7f, .7f, 1f);
final ColorMatrix saturationMatrix = new ColorMatrix();
saturationMatrix.setSaturation(0f);
matrix.setConcat(saturationMatrix, scaleMatrix);
}
bag.mImageIcon.setColorFilter(new ColorMatrixColorFilter(matrix));
// filename
bag.mTxtFileName.setText(file.getSecondName());
@ -316,6 +306,8 @@ public class IFileAdapter extends BaseAdapter {
else
bag.mTxtFileInfo.setText(String.format("%s, %s", Converter.sizeToStr(file.length()), time));
final boolean isAccessible = FileUtils.isAccessible(file, mFilenameRegexp);
bag.mImageIcon.setEnabled(isAccessible);
bag.mTxtFileName.setEnabled(isAccessible);
bag.mTxtFileInfo.setEnabled(isAccessible);

View file

@ -74,9 +74,9 @@ public class FileUtils {
if (filterMode == IFileProvider.FilterMode.DirectoriesOnly) {
if (file instanceof File && !((File)file).canWrite()) {
if (file instanceof ParentFile) {
return R.drawable.afc_folder;
return R.drawable.afc_item_folder;
} else if (accessDenied(file)) {
return R.drawable.afc_folder;
return R.drawable.afc_item_folder;
} else {
return R.drawable.afc_folder_locked;
}
@ -84,7 +84,7 @@ public class FileUtils {
return R.drawable.afc_folder;
}
} else {
return R.drawable.afc_folder;
return R.drawable.afc_item_folder;
}
}