mirror of
https://github.com/geometer/FBReaderJ.git
synced 2025-10-05 10:49:24 +02:00
openTree mechanism has been changed: intents are used (for correct restoring after force closing)
This commit is contained in:
parent
592aa59c33
commit
6c38d394f5
6 changed files with 64 additions and 29 deletions
|
@ -47,7 +47,6 @@ import org.geometerplus.android.fbreader.tree.BaseActivity;
|
||||||
import org.geometerplus.android.fbreader.tree.ListAdapter;
|
import org.geometerplus.android.fbreader.tree.ListAdapter;
|
||||||
|
|
||||||
public class LibraryActivity extends BaseActivity implements MenuItem.OnMenuItemClickListener, View.OnCreateContextMenuListener {
|
public class LibraryActivity extends BaseActivity implements MenuItem.OnMenuItemClickListener, View.OnCreateContextMenuListener {
|
||||||
public static final String TREE_KEY_KEY = "TreeKey";
|
|
||||||
public static final String SELECTED_BOOK_PATH_KEY = "SelectedBookPath";
|
public static final String SELECTED_BOOK_PATH_KEY = "SelectedBookPath";
|
||||||
|
|
||||||
static Library LibraryInstance;
|
static Library LibraryInstance;
|
||||||
|
@ -70,11 +69,8 @@ public class LibraryActivity extends BaseActivity implements MenuItem.OnMenuItem
|
||||||
}
|
}
|
||||||
|
|
||||||
final FBTree.Key key = (FBTree.Key)getIntent().getSerializableExtra(TREE_KEY_KEY);
|
final FBTree.Key key = (FBTree.Key)getIntent().getSerializableExtra(TREE_KEY_KEY);
|
||||||
setCurrentTree(
|
setCurrentTree(getTreeByKey(key));
|
||||||
key != null
|
|
||||||
? LibraryInstance.getLibraryTree(key)
|
|
||||||
: LibraryInstance.getRootTree()
|
|
||||||
);
|
|
||||||
setTitle(getCurrentTree().getTreeTitle());
|
setTitle(getCurrentTree().getTreeTitle());
|
||||||
|
|
||||||
final String selectedBookPath = getIntent().getStringExtra(SELECTED_BOOK_PATH_KEY);
|
final String selectedBookPath = getIntent().getStringExtra(SELECTED_BOOK_PATH_KEY);
|
||||||
|
@ -87,12 +83,17 @@ public class LibraryActivity extends BaseActivity implements MenuItem.OnMenuItem
|
||||||
}
|
}
|
||||||
|
|
||||||
final ListAdapter adapter = new LibraryListAdapter(this, getCurrentTree().subTrees());
|
final ListAdapter adapter = new LibraryListAdapter(this, getCurrentTree().subTrees());
|
||||||
setSelection(adapter.getFirstSelectedItemIndex());
|
setSelection(adapter.getIndex(adapter.getFirstSelectedItem()));
|
||||||
getListView().setTextFilterEnabled(true);
|
getListView().setTextFilterEnabled(true);
|
||||||
|
|
||||||
getListView().setOnCreateContextMenuListener(this);
|
getListView().setOnCreateContextMenuListener(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected FBTree getTreeByKey(FBTree.Key key) {
|
||||||
|
return key != null ? LibraryInstance.getLibraryTree(key) : LibraryInstance.getRootTree();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onDestroy() {
|
protected void onDestroy() {
|
||||||
LibraryInstance = null;
|
LibraryInstance = null;
|
||||||
|
@ -150,6 +151,8 @@ public class LibraryActivity extends BaseActivity implements MenuItem.OnMenuItem
|
||||||
} else {
|
} else {
|
||||||
UIUtil.showErrorMessage(this, "bookNotFound");
|
UIUtil.showErrorMessage(this, "bookNotFound");
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
super.onNewIntent(intent);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -42,7 +42,7 @@ public class ItemsLoadingService extends Service {
|
||||||
if (doDownload) {
|
if (doDownload) {
|
||||||
context.startService(
|
context.startService(
|
||||||
new Intent(context.getApplicationContext(), ItemsLoadingService.class)
|
new Intent(context.getApplicationContext(), ItemsLoadingService.class)
|
||||||
.putExtra(Util.TREE_KEY_KEY, tree.getUniqueKey())
|
.putExtra(NetworkBaseActivity.TREE_KEY_KEY, tree.getUniqueKey())
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -89,7 +89,7 @@ public class ItemsLoadingService extends Service {
|
||||||
doStop();
|
doStop();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
intent.removeExtra(Util.TREE_KEY_KEY);
|
intent.removeExtra(NetworkBaseActivity.TREE_KEY_KEY);
|
||||||
|
|
||||||
if (!NetworkView.Instance().isInitialized()) {
|
if (!NetworkView.Instance().isInitialized()) {
|
||||||
doStop();
|
doStop();
|
||||||
|
|
|
@ -66,6 +66,12 @@ public class NetworkBaseActivity extends BaseActivity implements NetworkView.Eve
|
||||||
|
|
||||||
private volatile boolean myInProgress;
|
private volatile boolean myInProgress;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected FBTree getTreeByKey(FBTree.Key key) {
|
||||||
|
final NetworkLibrary library = NetworkLibrary.Instance();
|
||||||
|
return key != null ? library.getTreeByKey(key) : library.getRootTree();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreate(Bundle icicle) {
|
public void onCreate(Bundle icicle) {
|
||||||
super.onCreate(icicle);
|
super.onCreate(icicle);
|
||||||
|
|
|
@ -239,20 +239,18 @@ abstract class Util implements UserRegistrationConstants {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static final String TREE_KEY_KEY = "org.geometerplus.android.fbreader.network.TreeKey";
|
|
||||||
|
|
||||||
static void openTree(Context context, NetworkTree tree) {
|
static void openTree(Context context, NetworkTree tree) {
|
||||||
final Class<?> clz = tree instanceof NetworkBookTree
|
final Class<?> clz = tree instanceof NetworkBookTree
|
||||||
? NetworkBookInfoActivity.class : NetworkBaseActivity.class;
|
? NetworkBookInfoActivity.class : NetworkBaseActivity.class;
|
||||||
context.startActivity(
|
context.startActivity(
|
||||||
new Intent(context.getApplicationContext(), clz)
|
new Intent(context.getApplicationContext(), clz)
|
||||||
.putExtra(TREE_KEY_KEY, tree.getUniqueKey())
|
.putExtra(NetworkBaseActivity.TREE_KEY_KEY, tree.getUniqueKey())
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static NetworkTree getTreeFromIntent(Intent intent) {
|
public static NetworkTree getTreeFromIntent(Intent intent) {
|
||||||
final NetworkLibrary library = NetworkLibrary.Instance();
|
final NetworkLibrary library = NetworkLibrary.Instance();
|
||||||
final NetworkTree.Key key = (NetworkTree.Key)intent.getSerializableExtra(TREE_KEY_KEY);
|
final NetworkTree.Key key = (NetworkTree.Key)intent.getSerializableExtra(NetworkBaseActivity.TREE_KEY_KEY);
|
||||||
return library.getTreeByKey(key);
|
return library.getTreeByKey(key);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,6 +30,11 @@ import org.geometerplus.android.util.UIUtil;
|
||||||
import org.geometerplus.fbreader.tree.FBTree;
|
import org.geometerplus.fbreader.tree.FBTree;
|
||||||
|
|
||||||
public abstract class BaseActivity extends ListActivity {
|
public abstract class BaseActivity extends ListActivity {
|
||||||
|
private static final String OPEN_TREE_ACTION = "org.fbreader.intent.OPEN_TREE";
|
||||||
|
|
||||||
|
public static final String TREE_KEY_KEY = "TreeKey";
|
||||||
|
public static final String SELECTED_TREE_KEY_KEY = "SelectedTreeKey";
|
||||||
|
|
||||||
private FBTree myCurrentTree;
|
private FBTree myCurrentTree;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -62,9 +67,7 @@ public abstract class BaseActivity extends ListActivity {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (keyCode == KeyEvent.KEYCODE_BACK && myCurrentTree.Parent != null) {
|
if (keyCode == KeyEvent.KEYCODE_BACK && myCurrentTree.Parent != null) {
|
||||||
final FBTree oldTree = myCurrentTree;
|
openTree(myCurrentTree.Parent, myCurrentTree);
|
||||||
openTree(myCurrentTree.Parent);
|
|
||||||
setSelection(getListAdapter().getIndex(oldTree));
|
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
return super.onKeyDown(keyCode, event);
|
return super.onKeyDown(keyCode, event);
|
||||||
|
@ -72,6 +75,10 @@ public abstract class BaseActivity extends ListActivity {
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void openTree(final FBTree tree) {
|
protected void openTree(final FBTree tree) {
|
||||||
|
openTree(tree, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void openTree(final FBTree tree, final FBTree treeToSelect) {
|
||||||
switch (tree.getOpeningStatus()) {
|
switch (tree.getOpeningStatus()) {
|
||||||
case WAIT_FOR_OPEN:
|
case WAIT_FOR_OPEN:
|
||||||
case ALWAYS_RELOAD_BEFORE_OPENING:
|
case ALWAYS_RELOAD_BEFORE_OPENING:
|
||||||
|
@ -86,29 +93,52 @@ public abstract class BaseActivity extends ListActivity {
|
||||||
},
|
},
|
||||||
new Runnable() {
|
new Runnable() {
|
||||||
public void run() {
|
public void run() {
|
||||||
openTreeInternal(tree);
|
openTreeInternal(tree, treeToSelect);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
tree.waitForOpening();
|
tree.waitForOpening();
|
||||||
openTreeInternal(tree);
|
openTreeInternal(tree, treeToSelect);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
openTreeInternal(tree);
|
openTreeInternal(tree, treeToSelect);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void openTreeInternal(FBTree tree) {
|
protected abstract FBTree getTreeByKey(FBTree.Key key);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onNewIntent(Intent intent) {
|
||||||
|
if (OPEN_TREE_ACTION.equals(intent.getAction())) {
|
||||||
|
final FBTree.Key key = (FBTree.Key)intent.getSerializableExtra(TREE_KEY_KEY);
|
||||||
|
final FBTree.Key selectedKey = (FBTree.Key)intent.getSerializableExtra(SELECTED_TREE_KEY_KEY);
|
||||||
|
myCurrentTree = getTreeByKey(key);
|
||||||
|
final ListAdapter adapter = getListAdapter();
|
||||||
|
adapter.replaceAll(myCurrentTree.subTrees());
|
||||||
|
setTitle(myCurrentTree.getTreeTitle());
|
||||||
|
final FBTree selectedTree =
|
||||||
|
selectedKey != null ? getTreeByKey(selectedKey) : adapter.getFirstSelectedItem();
|
||||||
|
setSelection(adapter.getIndex(selectedTree));
|
||||||
|
} else {
|
||||||
|
super.onNewIntent(intent);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void openTreeInternal(FBTree tree, FBTree treeToSelect) {
|
||||||
switch (tree.getOpeningStatus()) {
|
switch (tree.getOpeningStatus()) {
|
||||||
case READY_TO_OPEN:
|
case READY_TO_OPEN:
|
||||||
case ALWAYS_RELOAD_BEFORE_OPENING:
|
case ALWAYS_RELOAD_BEFORE_OPENING:
|
||||||
myCurrentTree = tree;
|
startActivity(new Intent(this, getClass())
|
||||||
getListAdapter().replaceAll(myCurrentTree.subTrees());
|
.setAction(OPEN_TREE_ACTION)
|
||||||
setTitle(myCurrentTree.getTreeTitle());
|
.putExtra(TREE_KEY_KEY, tree.getUniqueKey())
|
||||||
setSelection(getListAdapter().getFirstSelectedItemIndex());
|
.putExtra(
|
||||||
|
SELECTED_TREE_KEY_KEY,
|
||||||
|
treeToSelect != null ? treeToSelect.getUniqueKey() : null
|
||||||
|
)
|
||||||
|
);
|
||||||
break;
|
break;
|
||||||
case CANNOT_OPEN:
|
case CANNOT_OPEN:
|
||||||
UIUtil.showErrorMessage(BaseActivity.this, tree.getOpeningStatusMessage());
|
UIUtil.showErrorMessage(BaseActivity.this, tree.getOpeningStatusMessage());
|
||||||
|
|
|
@ -95,16 +95,14 @@ public abstract class ListAdapter extends BaseAdapter {
|
||||||
return myItems.indexOf(item);
|
return myItems.indexOf(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getFirstSelectedItemIndex() {
|
public FBTree getFirstSelectedItem() {
|
||||||
int index = 0;
|
|
||||||
synchronized (myItems) {
|
synchronized (myItems) {
|
||||||
for (FBTree t : myItems) {
|
for (FBTree t : myItems) {
|
||||||
if (myActivity.isTreeSelected(t)) {
|
if (myActivity.isTreeSelected(t)) {
|
||||||
return index;
|
return t;
|
||||||
}
|
}
|
||||||
++index;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return -1;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue