1
0
Fork 0
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:
Nikolay Pultsin 2011-07-16 10:46:39 +01:00
parent 592aa59c33
commit 6c38d394f5
6 changed files with 64 additions and 29 deletions

View file

@ -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);
} }
} }

View file

@ -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();

View file

@ -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);

View file

@ -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);
} }
} }

View file

@ -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());

View file

@ -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;
} }
} }