mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-23 07:27:22 +01:00
make group head view selectable, and separate group and game selection
so that only one type can be selected at once. Combine all three menus into one, but only enable subsets equivalent to the old menus depending on what's selected. Snapshot: menus pretty much don't work.
This commit is contained in:
parent
9fe34e4183
commit
43e69c7627
8 changed files with 311 additions and 257 deletions
|
@ -1,19 +0,0 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
|
|
||||||
<menu xmlns:android="http://schemas.android.com/apk/res/android">
|
|
||||||
<item android:id="@+id/list_group_default"
|
|
||||||
android:title="@string/list_group_default"
|
|
||||||
/>
|
|
||||||
<item android:id="@+id/list_group_rename"
|
|
||||||
android:title="@string/list_group_rename"
|
|
||||||
/>
|
|
||||||
<item android:id="@+id/list_group_moveup"
|
|
||||||
android:title="@string/list_group_moveup"
|
|
||||||
/>
|
|
||||||
<item android:id="@+id/list_group_movedown"
|
|
||||||
android:title="@string/list_group_movedown"
|
|
||||||
/>
|
|
||||||
<item android:id="@+id/list_group_delete"
|
|
||||||
android:title="@string/list_group_delete"
|
|
||||||
/>
|
|
||||||
</menu>
|
|
|
@ -1,44 +0,0 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
|
|
||||||
<menu xmlns:android="http://schemas.android.com/apk/res/android">
|
|
||||||
<item android:id="@+id/list_item_rename"
|
|
||||||
android:title="@string/list_item_rename"
|
|
||||||
/>
|
|
||||||
<item android:id="@+id/list_item_move"
|
|
||||||
android:title="@string/list_item_move"
|
|
||||||
/>
|
|
||||||
<item android:id="@+id/list_item_reset"
|
|
||||||
android:title="@string/list_item_reset"
|
|
||||||
/>
|
|
||||||
<item android:id="@+id/list_item_new_from"
|
|
||||||
android:title="@string/list_item_new_from"
|
|
||||||
/>
|
|
||||||
<item android:id="@+id/list_item_copy"
|
|
||||||
android:title="@string/list_item_copy"
|
|
||||||
/>
|
|
||||||
|
|
||||||
<item android:title="(rest deprecated)"/>
|
|
||||||
|
|
||||||
<item android:id="@+id/list_item_delete"
|
|
||||||
android:title="@string/list_item_delete"
|
|
||||||
/>
|
|
||||||
<item android:id="@+id/list_item_config"
|
|
||||||
android:title="@string/list_item_config"
|
|
||||||
/>
|
|
||||||
|
|
||||||
<!-- <item android:id="@+id/list_item_hide" -->
|
|
||||||
<!-- android:title="@string/list_item_hide" -->
|
|
||||||
<!-- /> -->
|
|
||||||
<!-- <item android:id="@+id/list_item_move_up" -->
|
|
||||||
<!-- android:title="@string/list_item_move_up" -->
|
|
||||||
<!-- /> -->
|
|
||||||
<!-- <item android:id="@+id/list_item_move_down" -->
|
|
||||||
<!-- android:title="@string/list_item_move_down" -->
|
|
||||||
<!-- /> -->
|
|
||||||
<!-- <item android:id="@+id/list_item_move_to_top" -->
|
|
||||||
<!-- android:title="@string/list_item_move_to_top" -->
|
|
||||||
<!-- /> -->
|
|
||||||
<!-- <item android:id="@+id/list_item_move_to_bottom" -->
|
|
||||||
<!-- android:title="@string/list_item_move_to_bottom" -->
|
|
||||||
<!-- /> -->
|
|
||||||
</menu>
|
|
|
@ -11,6 +11,13 @@
|
||||||
android:icon="@drawable/ic_action_delete"
|
android:icon="@drawable/ic_action_delete"
|
||||||
android:showAsAction="ifRoom"
|
android:showAsAction="ifRoom"
|
||||||
/>
|
/>
|
||||||
|
|
||||||
|
<item android:id="@+id/list_group_delete"
|
||||||
|
android:title="@string/list_group_delete"
|
||||||
|
android:icon="@drawable/ic_action_delete"
|
||||||
|
android:showAsAction="ifRoom"
|
||||||
|
/>
|
||||||
|
|
||||||
<item android:id="@+id/listl_item_config"
|
<item android:id="@+id/listl_item_config"
|
||||||
android:title="@string/list_item_config"
|
android:title="@string/list_item_config"
|
||||||
android:icon="@drawable/content_edit"
|
android:icon="@drawable/content_edit"
|
||||||
|
@ -42,6 +49,38 @@
|
||||||
android:title="@string/gamel_menu_checkmoves"
|
android:title="@string/gamel_menu_checkmoves"
|
||||||
android:icon="@drawable/stat_notify_sync"
|
android:icon="@drawable/stat_notify_sync"
|
||||||
/>
|
/>
|
||||||
|
|
||||||
|
<!-- Game items -->
|
||||||
|
<item android:id="@+id/list_item_rename"
|
||||||
|
android:title="@string/list_item_rename"
|
||||||
|
/>
|
||||||
|
<item android:id="@+id/list_item_move"
|
||||||
|
android:title="@string/list_item_move"
|
||||||
|
/>
|
||||||
|
<item android:id="@+id/list_item_reset"
|
||||||
|
android:title="@string/list_item_reset"
|
||||||
|
/>
|
||||||
|
<item android:id="@+id/list_item_new_from"
|
||||||
|
android:title="@string/list_item_new_from"
|
||||||
|
/>
|
||||||
|
<item android:id="@+id/list_item_copy"
|
||||||
|
android:title="@string/list_item_copy"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<!-- Group items -->
|
||||||
|
<item android:id="@+id/list_group_default"
|
||||||
|
android:title="@string/list_group_default"
|
||||||
|
/>
|
||||||
|
<item android:id="@+id/list_group_rename"
|
||||||
|
android:title="@string/list_group_rename"
|
||||||
|
/>
|
||||||
|
<item android:id="@+id/list_group_moveup"
|
||||||
|
android:title="@string/list_group_moveup"
|
||||||
|
/>
|
||||||
|
<item android:id="@+id/list_group_movedown"
|
||||||
|
android:title="@string/list_group_movedown"
|
||||||
|
/>
|
||||||
|
|
||||||
<!-- Debug only menuitems -->
|
<!-- Debug only menuitems -->
|
||||||
<item android:id="@+id/gamel_menu_checkupdates"
|
<item android:id="@+id/gamel_menu_checkupdates"
|
||||||
android:title="@string/gamel_menu_checkupdates"
|
android:title="@string/gamel_menu_checkupdates"
|
||||||
|
@ -53,5 +92,4 @@
|
||||||
android:title="@string/gamel_menu_loaddb"
|
android:title="@string/gamel_menu_loaddb"
|
||||||
/>
|
/>
|
||||||
|
|
||||||
<!-- ic_menu_archive.png -->
|
|
||||||
</menu>
|
</menu>
|
||||||
|
|
|
@ -21,6 +21,7 @@ package org.eehouse.android.xw4;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.graphics.Canvas;
|
import android.graphics.Canvas;
|
||||||
|
import android.graphics.drawable.Drawable;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
@ -28,6 +29,8 @@ import android.widget.TextView;
|
||||||
class ExpiringTextView extends TextView {
|
class ExpiringTextView extends TextView {
|
||||||
private ExpiringDelegate m_delegate = null;
|
private ExpiringDelegate m_delegate = null;
|
||||||
private Context m_context;
|
private Context m_context;
|
||||||
|
private Drawable m_origDrawable;
|
||||||
|
protected boolean m_selected = false;
|
||||||
|
|
||||||
public ExpiringTextView( Context context, AttributeSet attrs )
|
public ExpiringTextView( Context context, AttributeSet attrs )
|
||||||
{
|
{
|
||||||
|
@ -52,6 +55,17 @@ class ExpiringTextView extends TextView {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void toggleSelected()
|
||||||
|
{
|
||||||
|
m_selected = !m_selected;
|
||||||
|
if ( m_selected ) {
|
||||||
|
m_origDrawable = getBackground();
|
||||||
|
setBackgroundColor( XWApp.SEL_COLOR );
|
||||||
|
} else {
|
||||||
|
setBackgroundDrawable( m_origDrawable );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onDraw( Canvas canvas )
|
protected void onDraw( Canvas canvas )
|
||||||
{
|
{
|
||||||
|
|
|
@ -49,11 +49,15 @@ public class GameListAdapter implements ExpandableListAdapter {
|
||||||
private long[] m_positions;
|
private long[] m_positions;
|
||||||
|
|
||||||
public interface LoadItemCB {
|
public interface LoadItemCB {
|
||||||
public void itemClicked( long rowid, GameSummary summary );
|
public void itemClicked( Object clicked, GameSummary summary );
|
||||||
public void itemToggled( long rowid, boolean selected );
|
public void itemToggled( Object toggled, boolean selected );
|
||||||
public boolean getSelected( long rowid );
|
public boolean getSelected( long rowid );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public interface ClickHandler {
|
||||||
|
public void longClicked();
|
||||||
|
}
|
||||||
|
|
||||||
public GameListAdapter( Context context, ExpandableListView list,
|
public GameListAdapter( Context context, ExpandableListView list,
|
||||||
Handler handler, LoadItemCB cb, long[] positions,
|
Handler handler, LoadItemCB cb, long[] positions,
|
||||||
String fieldName )
|
String fieldName )
|
||||||
|
@ -152,9 +156,14 @@ public class GameListAdapter implements ExpandableListAdapter {
|
||||||
return ggi.m_name;
|
return ggi.m_name;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void clearSelected( Set<Long> rowids )
|
public void clearSelectedRows( Set<Long> rowids )
|
||||||
{
|
{
|
||||||
deselect( rowids );
|
deselectRows( rowids );
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clearSelectedGroups( HashSet<Integer> groups )
|
||||||
|
{
|
||||||
|
deselectGroups( groups );
|
||||||
}
|
}
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////
|
||||||
|
@ -182,7 +191,7 @@ public class GameListAdapter implements ExpandableListAdapter {
|
||||||
for ( long rowid : rowids ) {
|
for ( long rowid : rowids ) {
|
||||||
asSet.add( rowid );
|
asSet.add( rowid );
|
||||||
}
|
}
|
||||||
deselect( asSet );
|
deselectRows( asSet );
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onGroupExpanded( int groupPosition )
|
public void onGroupExpanded( int groupPosition )
|
||||||
|
@ -232,9 +241,8 @@ public class GameListAdapter implements ExpandableListAdapter {
|
||||||
// if ( null != convertView ) {
|
// if ( null != convertView ) {
|
||||||
// DbgUtils.logf( "getGroupView gave non-null convertView" );
|
// DbgUtils.logf( "getGroupView gave non-null convertView" );
|
||||||
// }
|
// }
|
||||||
GameListGroup view = (GameListGroup)
|
GameListGroup view =
|
||||||
Utils.inflate(m_context, R.layout.game_list_group );
|
GameListGroup.makeForPosition( m_context, groupPosition, m_cb );
|
||||||
view.setGroupPosition( groupPosition );
|
|
||||||
|
|
||||||
if ( !isExpanded ) {
|
if ( !isExpanded ) {
|
||||||
GameGroupInfo ggi = getInfoForGroup( groupPosition );
|
GameGroupInfo ggi = getInfoForGroup( groupPosition );
|
||||||
|
@ -364,7 +372,7 @@ public class GameListAdapter implements ExpandableListAdapter {
|
||||||
return gameInfo().get( getPositions()[groupPosition] );
|
return gameInfo().get( getPositions()[groupPosition] );
|
||||||
}
|
}
|
||||||
|
|
||||||
private void deselect( Set<Long> rowids )
|
private void deselectRows( Set<Long> rowids )
|
||||||
{
|
{
|
||||||
GameListItem[] items = new GameListItem[rowids.size()];
|
GameListItem[] items = new GameListItem[rowids.size()];
|
||||||
getGameItemsFor( rowids, items );
|
getGameItemsFor( rowids, items );
|
||||||
|
@ -375,6 +383,16 @@ public class GameListAdapter implements ExpandableListAdapter {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void deselectGroups( HashSet<Integer> groups )
|
||||||
|
{
|
||||||
|
groups = (HashSet<Integer>)groups.clone();
|
||||||
|
for ( Iterator<Integer>iter = groups.iterator();
|
||||||
|
iter.hasNext(); ) {
|
||||||
|
GameListGroup group = getGroupItemFor( iter.next() );
|
||||||
|
group.setSelected( false );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void getGameItemsFor( Set<Long> rowids, GameListItem[] items )
|
private void getGameItemsFor( Set<Long> rowids, GameListItem[] items )
|
||||||
{
|
{
|
||||||
int next = 0;
|
int next = 0;
|
||||||
|
|
|
@ -23,11 +23,27 @@ package org.eehouse.android.xw4;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.graphics.Canvas;
|
import android.graphics.Canvas;
|
||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
|
import android.view.View;
|
||||||
|
|
||||||
import org.eehouse.android.xw4.DBUtils.GameGroupInfo;
|
import org.eehouse.android.xw4.DBUtils.GameGroupInfo;
|
||||||
|
|
||||||
public class GameListGroup extends ExpiringTextView {
|
public class GameListGroup extends ExpiringTextView
|
||||||
|
implements GameListAdapter.ClickHandler
|
||||||
|
{
|
||||||
private int m_groupPosition;
|
private int m_groupPosition;
|
||||||
|
private boolean m_expanded;
|
||||||
|
private GameListAdapter.LoadItemCB m_cb;
|
||||||
|
|
||||||
|
public static GameListGroup makeForPosition( Context context,
|
||||||
|
int groupPosition,
|
||||||
|
GameListAdapter.LoadItemCB cb )
|
||||||
|
{
|
||||||
|
GameListGroup result =
|
||||||
|
(GameListGroup)Utils.inflate( context, R.layout.game_list_group );
|
||||||
|
result.m_cb = cb;
|
||||||
|
result.m_groupPosition = groupPosition;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
public GameListGroup( Context cx, AttributeSet as )
|
public GameListGroup( Context cx, AttributeSet as )
|
||||||
{
|
{
|
||||||
|
@ -43,4 +59,25 @@ public class GameListGroup extends ExpiringTextView {
|
||||||
{
|
{
|
||||||
return m_groupPosition;
|
return m_groupPosition;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setSelected( boolean selected )
|
||||||
|
{
|
||||||
|
// If new value and state not in sync, force change in state
|
||||||
|
if ( selected != m_selected ) {
|
||||||
|
toggleSelected();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// GameListAdapter.ClickHandler interface
|
||||||
|
public void longClicked()
|
||||||
|
{
|
||||||
|
toggleSelected();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void toggleSelected()
|
||||||
|
{
|
||||||
|
super.toggleSelected();
|
||||||
|
m_cb.itemToggled( this, m_selected );
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,7 +43,7 @@ import org.eehouse.android.xw4.jni.CommsAddrRec.CommsConnType;
|
||||||
import org.eehouse.android.xw4.jni.GameSummary;
|
import org.eehouse.android.xw4.jni.GameSummary;
|
||||||
|
|
||||||
public class GameListItem extends LinearLayout
|
public class GameListItem extends LinearLayout
|
||||||
implements View.OnClickListener {
|
implements View.OnClickListener, GameListAdapter.ClickHandler {
|
||||||
|
|
||||||
private static HashSet<Long> s_invalRows = new HashSet<Long>();
|
private static HashSet<Long> s_invalRows = new HashSet<Long>();
|
||||||
|
|
||||||
|
@ -62,6 +62,7 @@ public class GameListItem extends LinearLayout
|
||||||
private int m_loadingCount;
|
private int m_loadingCount;
|
||||||
private int m_groupPosition;
|
private int m_groupPosition;
|
||||||
private Drawable m_origDrawable;
|
private Drawable m_origDrawable;
|
||||||
|
private boolean m_selected = false;
|
||||||
|
|
||||||
public GameListItem( Context cx, AttributeSet as )
|
public GameListItem( Context cx, AttributeSet as )
|
||||||
{
|
{
|
||||||
|
@ -71,6 +72,18 @@ public class GameListItem extends LinearLayout
|
||||||
m_rowid = DBUtils.ROWID_NOTFOUND;
|
m_rowid = DBUtils.ROWID_NOTFOUND;
|
||||||
m_lastMoveTime = 0;
|
m_lastMoveTime = 0;
|
||||||
m_loadingCount = 0;
|
m_loadingCount = 0;
|
||||||
|
|
||||||
|
setOnClickListener( new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick( View v ) {
|
||||||
|
// if selected, just un-select
|
||||||
|
if ( m_selected ) {
|
||||||
|
toggleSelected();
|
||||||
|
} else if ( null != m_summary ) {
|
||||||
|
m_cb.itemClicked( this, m_summary );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} );
|
||||||
}
|
}
|
||||||
|
|
||||||
private void init( Handler handler, long rowid, int groupPosition,
|
private void init( Handler handler, long rowid, int groupPosition,
|
||||||
|
@ -105,7 +118,7 @@ public class GameListItem extends LinearLayout
|
||||||
public void setSelected( boolean selected )
|
public void setSelected( boolean selected )
|
||||||
{
|
{
|
||||||
// If new value and state not in sync, force change in state
|
// If new value and state not in sync, force change in state
|
||||||
if ( selected != (null != m_origDrawable) ) {
|
if ( selected != m_selected ) {
|
||||||
toggleSelected();
|
toggleSelected();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -214,24 +227,12 @@ public class GameListItem extends LinearLayout
|
||||||
return state;
|
return state;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setData( final GameSummary summary )
|
private void setData( GameSummary summary )
|
||||||
{
|
{
|
||||||
if ( null != summary ) {
|
if ( null != summary ) {
|
||||||
TextView tview;
|
TextView tview;
|
||||||
String state = setName();
|
String state = setName();
|
||||||
|
|
||||||
setOnClickListener( new View.OnClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onClick( View v ) {
|
|
||||||
// if selected, just un-select
|
|
||||||
if ( null != m_origDrawable ) {
|
|
||||||
toggleSelected();
|
|
||||||
} else {
|
|
||||||
m_cb.itemClicked( m_rowid, summary );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} );
|
|
||||||
|
|
||||||
LinearLayout list =
|
LinearLayout list =
|
||||||
(LinearLayout)findViewById( R.id.player_list );
|
(LinearLayout)findViewById( R.id.player_list );
|
||||||
list.removeAllViews();
|
list.removeAllViews();
|
||||||
|
@ -305,14 +306,14 @@ public class GameListItem extends LinearLayout
|
||||||
|
|
||||||
private void toggleSelected()
|
private void toggleSelected()
|
||||||
{
|
{
|
||||||
if ( null == m_origDrawable ) {
|
m_selected = !m_selected;
|
||||||
|
if ( m_selected ) {
|
||||||
m_origDrawable = getBackground();
|
m_origDrawable = getBackground();
|
||||||
setBackgroundColor( XWApp.SEL_COLOR );
|
setBackgroundColor( XWApp.SEL_COLOR );
|
||||||
} else {
|
} else {
|
||||||
setBackgroundDrawable( m_origDrawable );
|
setBackgroundDrawable( m_origDrawable );
|
||||||
m_origDrawable = null;
|
|
||||||
}
|
}
|
||||||
m_cb.itemToggled( m_rowid, null != m_origDrawable );
|
m_cb.itemToggled( this, m_selected );
|
||||||
}
|
}
|
||||||
|
|
||||||
private class LoadItemTask extends AsyncTask<Void, Void, GameSummary> {
|
private class LoadItemTask extends AsyncTask<Void, Void, GameSummary> {
|
||||||
|
@ -334,7 +335,7 @@ public class GameListItem extends LinearLayout
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( m_cb.getSelected( m_rowid ) && null != m_origDrawable ) {
|
if ( m_cb.getSelected( m_rowid ) && m_selected ) {
|
||||||
toggleSelected();
|
toggleSelected();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -372,5 +373,11 @@ public class GameListItem extends LinearLayout
|
||||||
// }
|
// }
|
||||||
// return TextUtils.join(",", strs );
|
// return TextUtils.join(",", strs );
|
||||||
// }
|
// }
|
||||||
|
// GameListAdapter.ClickHandler interface
|
||||||
|
|
||||||
|
public void longClicked()
|
||||||
|
{
|
||||||
|
toggleSelected();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,16 +32,15 @@ import android.os.Bundle;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.os.Message;
|
import android.os.Message;
|
||||||
import android.preference.PreferenceManager;
|
import android.preference.PreferenceManager;
|
||||||
import android.view.ContextMenu.ContextMenuInfo;
|
|
||||||
import android.view.ContextMenu;
|
|
||||||
import android.view.Menu;
|
import android.view.Menu;
|
||||||
import android.view.MenuInflater;
|
import android.view.MenuInflater;
|
||||||
import android.view.MenuItem;
|
import android.view.MenuItem;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
|
import android.widget.AdapterView.OnItemLongClickListener;
|
||||||
import android.widget.AdapterView;
|
import android.widget.AdapterView;
|
||||||
import android.widget.Button;
|
import android.widget.Button;
|
||||||
import android.widget.EditText;
|
import android.widget.EditText;
|
||||||
import android.widget.ExpandableListView.ExpandableListContextMenuInfo;
|
// import android.widget.ExpandableListView.ExpandableListContextMenuInfo;
|
||||||
import android.widget.ExpandableListView;
|
import android.widget.ExpandableListView;
|
||||||
import android.widget.LinearLayout;
|
import android.widget.LinearLayout;
|
||||||
import android.widget.ListView;
|
import android.widget.ListView;
|
||||||
|
@ -59,7 +58,8 @@ import junit.framework.Assert;
|
||||||
import org.eehouse.android.xw4.jni.*;
|
import org.eehouse.android.xw4.jni.*;
|
||||||
|
|
||||||
public class GamesList extends XWExpandableListActivity
|
public class GamesList extends XWExpandableListActivity
|
||||||
implements DBUtils.DBChangeListener,
|
implements OnItemLongClickListener,
|
||||||
|
DBUtils.DBChangeListener,
|
||||||
GameListAdapter.LoadItemCB,
|
GameListAdapter.LoadItemCB,
|
||||||
DictImportActivity.DownloadFinishedListener {
|
DictImportActivity.DownloadFinishedListener {
|
||||||
|
|
||||||
|
@ -91,10 +91,33 @@ public class GamesList extends XWExpandableListActivity
|
||||||
DELETE_SELGAMES,
|
DELETE_SELGAMES,
|
||||||
OPEN_GAME
|
OPEN_GAME
|
||||||
};
|
};
|
||||||
private static final int[] DEBUGITEMS = { R.id.gamel_menu_loaddb
|
private static final int[] DEBUGITEMS = {
|
||||||
|
R.id.gamel_menu_loaddb
|
||||||
, R.id.gamel_menu_storedb
|
, R.id.gamel_menu_storedb
|
||||||
, R.id.gamel_menu_checkupdates
|
, R.id.gamel_menu_checkupdates
|
||||||
};
|
};
|
||||||
|
private static final int[] NOSEL_ITEMS = {
|
||||||
|
R.id.gamel_menu_newgame
|
||||||
|
,R.id.gamel_menu_newgroup
|
||||||
|
,R.id.gamel_menu_prefs
|
||||||
|
,R.id.gamel_menu_dicts
|
||||||
|
,R.id.gamel_menu_about
|
||||||
|
,R.id.gamel_menu_email
|
||||||
|
,R.id.gamel_menu_checkmoves
|
||||||
|
};
|
||||||
|
private static final int[] ONEGAME_ITEMS = {
|
||||||
|
R.id.listl_item_config
|
||||||
|
,R.id.list_item_rename
|
||||||
|
,R.id.list_item_new_from
|
||||||
|
,R.id.list_item_copy
|
||||||
|
};
|
||||||
|
|
||||||
|
private static final int[] ONEGROUP_ITEMS = {
|
||||||
|
R.id.list_group_default
|
||||||
|
,R.id.list_group_rename
|
||||||
|
,R.id.list_group_moveup
|
||||||
|
,R.id.list_group_movedown
|
||||||
|
};
|
||||||
|
|
||||||
private static boolean s_firstShown = false;
|
private static boolean s_firstShown = false;
|
||||||
|
|
||||||
|
@ -110,7 +133,8 @@ public class GamesList extends XWExpandableListActivity
|
||||||
private NetLaunchInfo m_netLaunchInfo;
|
private NetLaunchInfo m_netLaunchInfo;
|
||||||
private GameNamer m_namer;
|
private GameNamer m_namer;
|
||||||
private boolean m_gameLaunched = false;
|
private boolean m_gameLaunched = false;
|
||||||
private HashSet<Long> m_selected;
|
private HashSet<Long> m_selectedRows;
|
||||||
|
private HashSet<Integer> m_selectedGroups;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Dialog onCreateDialog( int id )
|
protected Dialog onCreateDialog( int id )
|
||||||
|
@ -339,10 +363,11 @@ public class GamesList extends XWExpandableListActivity
|
||||||
|
|
||||||
getBundledData( savedInstanceState );
|
getBundledData( savedInstanceState );
|
||||||
|
|
||||||
m_selected = new HashSet<Long>();
|
m_selectedRows = new HashSet<Long>();
|
||||||
|
m_selectedGroups = new HashSet<Integer>();
|
||||||
|
|
||||||
setContentView(R.layout.game_list);
|
setContentView(R.layout.game_list);
|
||||||
registerForContextMenu( getExpandableListView() );
|
ExpandableListView listview = getExpandableListView();
|
||||||
DBUtils.setDBChangeListener( this );
|
DBUtils.setDBChangeListener( this );
|
||||||
|
|
||||||
boolean isUpgrade = Utils.firstBootThisVersion( this );
|
boolean isUpgrade = Utils.firstBootThisVersion( this );
|
||||||
|
@ -354,11 +379,12 @@ public class GamesList extends XWExpandableListActivity
|
||||||
|
|
||||||
String field = CommonPrefs.getSummaryField( this );
|
String field = CommonPrefs.getSummaryField( this );
|
||||||
long[] positions = XWPrefs.getGroupPositions( this );
|
long[] positions = XWPrefs.getGroupPositions( this );
|
||||||
m_adapter = new GameListAdapter( this, getExpandableListView(),
|
m_adapter = new GameListAdapter( this, listview, new Handler(),
|
||||||
new Handler(), this, positions,
|
this, positions, field );
|
||||||
field );
|
|
||||||
setListAdapter( m_adapter );
|
setListAdapter( m_adapter );
|
||||||
m_adapter.expandGroups( getExpandableListView() );
|
listview.setOnItemLongClickListener( this );
|
||||||
|
|
||||||
|
m_adapter.expandGroups( listview );
|
||||||
|
|
||||||
NetUtils.informOfDeaths( this );
|
NetUtils.informOfDeaths( this );
|
||||||
|
|
||||||
|
@ -431,6 +457,16 @@ public class GamesList extends XWExpandableListActivity
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// OnItemLongClickListener interface
|
||||||
|
public boolean onItemLongClick( AdapterView<?> parent, View view,
|
||||||
|
int position, long id ) {
|
||||||
|
boolean success = view instanceof GameListAdapter.ClickHandler;
|
||||||
|
if ( success ) {
|
||||||
|
((GameListAdapter.ClickHandler)view).longClicked();
|
||||||
|
}
|
||||||
|
return success;
|
||||||
|
}
|
||||||
|
|
||||||
// DBUtils.DBChangeListener interface
|
// DBUtils.DBChangeListener interface
|
||||||
public void gameSaved( final long rowid, final boolean countChanged )
|
public void gameSaved( final long rowid, final boolean countChanged )
|
||||||
{
|
{
|
||||||
|
@ -446,33 +482,47 @@ public class GamesList extends XWExpandableListActivity
|
||||||
}
|
}
|
||||||
|
|
||||||
// GameListAdapter.LoadItemCB interface
|
// GameListAdapter.LoadItemCB interface
|
||||||
public void itemClicked( long rowid, GameSummary summary )
|
public void itemClicked( Object clicked, GameSummary summary )
|
||||||
{
|
{
|
||||||
// We need a way to let the user get back to the basic-config
|
// We need a way to let the user get back to the basic-config
|
||||||
// dialog in case it was dismissed. That way it to check for
|
// dialog in case it was dismissed. That way it to check for
|
||||||
// an empty room name.
|
// an empty room name.
|
||||||
|
if ( clicked instanceof GameListItem ) {
|
||||||
if ( !m_gameLaunched ) {
|
if ( !m_gameLaunched ) {
|
||||||
|
long rowid = ((GameListItem)clicked).getRowID();
|
||||||
showNotAgainDlgThen( R.string.not_again_newselect,
|
showNotAgainDlgThen( R.string.not_again_newselect,
|
||||||
R.string.key_notagain_newselect,
|
R.string.key_notagain_newselect,
|
||||||
GamesActions.OPEN_GAME.ordinal(),
|
GamesActions.OPEN_GAME.ordinal(),
|
||||||
rowid, summary );
|
rowid, summary );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void itemToggled( long rowid, boolean selected )
|
public void itemToggled( Object toggled, boolean selected )
|
||||||
{
|
{
|
||||||
int countBefore = m_selected.size();
|
if ( toggled instanceof GameListItem ) {
|
||||||
|
long rowid = ((GameListItem)toggled).getRowID();
|
||||||
if ( selected ) {
|
if ( selected ) {
|
||||||
m_selected.add( rowid );
|
m_selectedRows.add( rowid );
|
||||||
|
clearSelectedGroups();
|
||||||
} else {
|
} else {
|
||||||
m_selected.remove( rowid );
|
m_selectedRows.remove( rowid );
|
||||||
|
}
|
||||||
|
} else if ( toggled instanceof GameListGroup ) {
|
||||||
|
int position = ((GameListGroup)toggled).getGroupPosition();
|
||||||
|
if ( selected ) {
|
||||||
|
m_selectedGroups.add( position );
|
||||||
|
clearSelectedRows();
|
||||||
|
} else {
|
||||||
|
m_selectedGroups.remove( position );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
Utils.invalidateOptionsMenuIf( this );
|
Utils.invalidateOptionsMenuIf( this );
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean getSelected( long rowid )
|
public boolean getSelected( long rowid )
|
||||||
{
|
{
|
||||||
return m_selected.contains( rowid );
|
return m_selectedRows.contains( rowid );
|
||||||
}
|
}
|
||||||
|
|
||||||
// BTService.MultiEventListener interface
|
// BTService.MultiEventListener interface
|
||||||
|
@ -548,77 +598,13 @@ public class GamesList extends XWExpandableListActivity
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onBackPressed() {
|
public void onBackPressed() {
|
||||||
if ( 0 == m_selected.size() ) {
|
if ( 0 == m_selectedRows.size() ) {
|
||||||
super.onBackPressed();
|
super.onBackPressed();
|
||||||
} else {
|
} else {
|
||||||
clearSelected();
|
clearSelectedRows();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onCreateContextMenu( ContextMenu menu, View view,
|
|
||||||
ContextMenuInfo menuInfo )
|
|
||||||
{
|
|
||||||
ExpandableListView.ExpandableListContextMenuInfo info
|
|
||||||
= (ExpandableListView.ExpandableListContextMenuInfo)menuInfo;
|
|
||||||
long packedPos = info.packedPosition;
|
|
||||||
int childPos = ExpandableListView.getPackedPositionChild( packedPos );
|
|
||||||
|
|
||||||
String name;
|
|
||||||
if ( 0 <= childPos ) { // game case
|
|
||||||
MenuInflater inflater = getMenuInflater();
|
|
||||||
inflater.inflate( R.menu.games_list_item_menu, menu );
|
|
||||||
|
|
||||||
long rowid = m_adapter.getRowIDFor( packedPos );
|
|
||||||
name = GameUtils.getName( this, rowid );
|
|
||||||
} else { // group case
|
|
||||||
MenuInflater inflater = getMenuInflater();
|
|
||||||
inflater.inflate( R.menu.games_list_group_menu, menu );
|
|
||||||
|
|
||||||
int pos = ExpandableListView.getPackedPositionGroup( packedPos );
|
|
||||||
name = m_adapter.groupNames()[pos];
|
|
||||||
|
|
||||||
if ( 0 == pos ) {
|
|
||||||
Utils.setItemEnabled( menu, R.id.list_group_moveup, false );
|
|
||||||
}
|
|
||||||
if ( pos + 1 == m_adapter.getGroupCount() ) {
|
|
||||||
Utils.setItemEnabled( menu, R.id.list_group_movedown, false );
|
|
||||||
}
|
|
||||||
if ( XWPrefs.getDefaultNewGameGroup( this )
|
|
||||||
== m_adapter.getGroupIDFor( pos ) ) {
|
|
||||||
Utils.setItemEnabled( menu, R.id.list_group_default, false );
|
|
||||||
Utils.setItemEnabled( menu, R.id.list_group_delete, false );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
menu.setHeaderTitle( getString( R.string.game_item_menu_titlef,
|
|
||||||
name ) );
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onContextItemSelected( MenuItem item )
|
|
||||||
{
|
|
||||||
ExpandableListContextMenuInfo info;
|
|
||||||
try {
|
|
||||||
info = (ExpandableListContextMenuInfo)item.getMenuInfo();
|
|
||||||
} catch (ClassCastException cce) {
|
|
||||||
DbgUtils.loge( cce );
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
long packedPos = info.packedPosition;
|
|
||||||
int childPos = ExpandableListView.getPackedPositionChild( packedPos );
|
|
||||||
int groupPos = ExpandableListView.getPackedPositionGroup(packedPos);
|
|
||||||
int menuID = item.getItemId();
|
|
||||||
boolean handled;
|
|
||||||
if ( 0 <= childPos ) {
|
|
||||||
long rowid = m_adapter.getRowIDFor( groupPos, childPos );
|
|
||||||
handled = handleGameMenuItem( menuID, rowid );
|
|
||||||
} else {
|
|
||||||
handled = handleGroupMenuItem( menuID, groupPos );
|
|
||||||
}
|
|
||||||
return handled;
|
|
||||||
} // onContextItemSelected
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onCreateOptionsMenu( Menu menu )
|
public boolean onCreateOptionsMenu( Menu menu )
|
||||||
{
|
{
|
||||||
|
@ -631,22 +617,38 @@ public class GamesList extends XWExpandableListActivity
|
||||||
@Override
|
@Override
|
||||||
public boolean onPrepareOptionsMenu( Menu menu )
|
public boolean onPrepareOptionsMenu( Menu menu )
|
||||||
{
|
{
|
||||||
|
int nGamesSelected = m_selectedRows.size();
|
||||||
|
int nGroupsSelected = m_selectedGroups.size();
|
||||||
|
boolean nothingSelected = 0 == (nGroupsSelected + nGamesSelected);
|
||||||
|
Assert.assertTrue( 0 == nGamesSelected || 0 == nGroupsSelected );
|
||||||
|
|
||||||
boolean visible = XWPrefs.getDebugEnabled( this );
|
boolean visible = XWPrefs.getDebugEnabled( this );
|
||||||
for ( int id : DEBUGITEMS ) {
|
for ( int id : DEBUGITEMS ) {
|
||||||
MenuItem item = menu.findItem( id );
|
Utils.setItemVisible( menu, id, nothingSelected && visible );
|
||||||
item.setVisible( visible );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( visible && !DBUtils.gameDBExists( this ) ) {
|
if ( visible && !DBUtils.gameDBExists( this ) ) {
|
||||||
MenuItem item = menu.findItem( R.id.gamel_menu_loaddb );
|
Utils.setItemVisible( menu, R.id.gamel_menu_loaddb, false );
|
||||||
item.setVisible( false );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int nSelected = m_selected.size();
|
for ( int id : NOSEL_ITEMS ) {
|
||||||
|
Utils.setItemVisible( menu, id, nothingSelected );
|
||||||
|
}
|
||||||
|
for ( int id : ONEGAME_ITEMS ) {
|
||||||
|
Utils.setItemVisible( menu, id, 1 == nGamesSelected );
|
||||||
|
}
|
||||||
|
for ( int id : ONEGROUP_ITEMS ) {
|
||||||
|
Utils.setItemVisible( menu, id, 1 == nGroupsSelected );
|
||||||
|
}
|
||||||
|
|
||||||
Utils.setItemVisible( menu, R.id.gamel_menu_newgame, 0 == nSelected );
|
// Multiples can be deleted
|
||||||
Utils.setItemVisible( menu, R.id.gamel_menu_delete, 0 < nSelected );
|
Utils.setItemVisible( menu, R.id.gamel_menu_delete,
|
||||||
Utils.setItemVisible( menu, R.id.listl_item_config, 1 == nSelected );
|
0 < nGamesSelected );
|
||||||
|
Utils.setItemVisible( menu, R.id.list_group_delete,
|
||||||
|
0 < nGroupsSelected );
|
||||||
|
// multiple games can be regrouped/reset
|
||||||
|
Utils.setItemVisible( menu, R.id.list_item_move, 0 < nGroupsSelected );
|
||||||
|
Utils.setItemVisible( menu, R.id.list_item_reset, 0 < nGroupsSelected );
|
||||||
|
|
||||||
return super.onPrepareOptionsMenu( menu );
|
return super.onPrepareOptionsMenu( menu );
|
||||||
}
|
}
|
||||||
|
@ -665,13 +667,13 @@ public class GamesList extends XWExpandableListActivity
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case R.id.listl_item_config:
|
case R.id.listl_item_config:
|
||||||
long rowid = m_selected.iterator().next();
|
long rowid = m_selectedRows.iterator().next();
|
||||||
GameUtils.doConfig( this, rowid, GameConfig.class );
|
GameUtils.doConfig( this, rowid, GameConfig.class );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case R.id.gamel_menu_delete:
|
case R.id.gamel_menu_delete:
|
||||||
String msg = Utils.format( this, R.string.confirm_seldeletesf,
|
String msg = Utils.format( this, R.string.confirm_seldeletesf,
|
||||||
m_selected.size() );
|
m_selectedRows.size() );
|
||||||
showConfirmThen( msg, R.string.button_delete,
|
showConfirmThen( msg, R.string.button_delete,
|
||||||
GamesActions.DELETE_SELGAMES.ordinal() );
|
GamesActions.DELETE_SELGAMES.ordinal() );
|
||||||
break;
|
break;
|
||||||
|
@ -745,13 +747,6 @@ public class GamesList extends XWExpandableListActivity
|
||||||
|
|
||||||
m_rowid = rowid;
|
m_rowid = rowid;
|
||||||
|
|
||||||
if ( R.id.list_item_delete == menuID
|
|
||||||
|| R.id.list_item_config == menuID ) {
|
|
||||||
showOKOnlyDialog( "This menu item is going away soon. Please select"
|
|
||||||
+ " games by tapping the left icons then use"
|
|
||||||
+ " action bar icons or the screen menu to operate"
|
|
||||||
+ " on the selection." );
|
|
||||||
} else {
|
|
||||||
if ( checkWarnNoDict( m_rowid ) ) {
|
if ( checkWarnNoDict( m_rowid ) ) {
|
||||||
switch ( menuID ) {
|
switch ( menuID ) {
|
||||||
case R.id.list_item_reset:
|
case R.id.list_item_reset:
|
||||||
|
@ -801,7 +796,6 @@ public class GamesList extends XWExpandableListActivity
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return handled;
|
return handled;
|
||||||
} // handleGameMenuItem
|
} // handleGameMenuItem
|
||||||
|
@ -1076,11 +1070,11 @@ public class GamesList extends XWExpandableListActivity
|
||||||
|
|
||||||
private void deleteSelected()
|
private void deleteSelected()
|
||||||
{
|
{
|
||||||
for ( Iterator<Long> iter = m_selected.iterator(); iter.hasNext(); ) {
|
for ( Iterator<Long> iter = m_selectedRows.iterator(); iter.hasNext(); ) {
|
||||||
long rowid = iter.next();
|
long rowid = iter.next();
|
||||||
GameUtils.deleteGame( this, rowid, false );
|
GameUtils.deleteGame( this, rowid, false );
|
||||||
}
|
}
|
||||||
m_selected.clear();
|
m_selectedRows.clear();
|
||||||
Utils.invalidateOptionsMenuIf( this );
|
Utils.invalidateOptionsMenuIf( this );
|
||||||
NetUtils.informOfDeaths( this );
|
NetUtils.informOfDeaths( this );
|
||||||
}
|
}
|
||||||
|
@ -1095,12 +1089,21 @@ public class GamesList extends XWExpandableListActivity
|
||||||
return madeGame;
|
return madeGame;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void clearSelected()
|
private void clearSelectedRows()
|
||||||
{
|
{
|
||||||
// clear any selection
|
// clear any selection
|
||||||
if ( 0 < m_selected.size() ) {
|
if ( 0 < m_selectedRows.size() ) {
|
||||||
m_adapter.clearSelected( m_selected );
|
m_adapter.clearSelectedRows( m_selectedRows );
|
||||||
m_selected.clear();
|
m_selectedRows.clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void clearSelectedGroups()
|
||||||
|
{
|
||||||
|
// clear any selection
|
||||||
|
if ( 0 < m_selectedGroups.size() ) {
|
||||||
|
m_adapter.clearSelectedGroups( m_selectedGroups );
|
||||||
|
m_selectedGroups.clear();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1119,7 +1122,7 @@ public class GamesList extends XWExpandableListActivity
|
||||||
if ( !m_gameLaunched ) {
|
if ( !m_gameLaunched ) {
|
||||||
m_gameLaunched = true;
|
m_gameLaunched = true;
|
||||||
GameUtils.launchGame( this, rowid, invited );
|
GameUtils.launchGame( this, rowid, invited );
|
||||||
clearSelected();
|
clearSelectedRows();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue