mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-07 05:24:46 +01:00
snapshot on the way to making studylists editable: add checkbox to xwlistitem. It's to be an alterative to long tap to select. Implement selectAll and deselectAll.
This commit is contained in:
parent
e7708ef439
commit
aa6fbf8605
7 changed files with 167 additions and 29 deletions
|
@ -13,6 +13,12 @@
|
||||||
android:background="@android:drawable/list_selector_background"
|
android:background="@android:drawable/list_selector_background"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<CheckBox android:id="@+id/checkbox"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:visibility="gone"
|
||||||
|
/>
|
||||||
|
|
||||||
<TextView android:id="@+id/text_item"
|
<TextView android:id="@+id/text_item"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
|
|
|
@ -1,6 +1,14 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
|
||||||
<menu xmlns:android="http://schemas.android.com/apk/res/android">
|
<menu xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
<item android:id="@+id/select_all"
|
||||||
|
android:title="@string/slmenu_select_all"
|
||||||
|
/>
|
||||||
|
|
||||||
|
<item android:id="@+id/deselect_all"
|
||||||
|
android:title="@string/slmenu_deselect_all"
|
||||||
|
/>
|
||||||
|
|
||||||
<item android:id="@+id/copy_all"
|
<item android:id="@+id/copy_all"
|
||||||
android:title="@string/slmenu_copy_all"
|
android:title="@string/slmenu_copy_all"
|
||||||
android:icon="@drawable/content_copy__gen"
|
android:icon="@drawable/content_copy__gen"
|
||||||
|
|
|
@ -2227,4 +2227,9 @@
|
||||||
app that supports pasting text, e.g. an email app.</string>
|
app that supports pasting text, e.g. an email app.</string>
|
||||||
|
|
||||||
<string name="lookup_title">Word lookup</string>
|
<string name="lookup_title">Word lookup</string>
|
||||||
|
|
||||||
|
<string name="slmenu_select_all">Select all</string>
|
||||||
|
<string name="slmenu_deselect_all">Deselect all</string>
|
||||||
|
<string name="sel_wordsf">Words: %d</string>
|
||||||
|
|
||||||
</resources>
|
</resources>
|
||||||
|
|
|
@ -83,7 +83,7 @@ public class DictsActivity extends XWExpandableListActivity
|
||||||
private static HashMap<MenuItem, DictAndLoc> s_itemData;
|
private static HashMap<MenuItem, DictAndLoc> s_itemData;
|
||||||
|
|
||||||
private String[] m_langs;
|
private String[] m_langs;
|
||||||
private String m_download;
|
private String m_downloadStr;
|
||||||
private ExpandableListView m_expView;
|
private ExpandableListView m_expView;
|
||||||
private String[] m_locNames;
|
private String[] m_locNames;
|
||||||
private DictListAdapter m_adapter;
|
private DictListAdapter m_adapter;
|
||||||
|
@ -129,9 +129,8 @@ public class DictsActivity extends XWExpandableListActivity
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( null == view ) {
|
if ( null == view ) {
|
||||||
view = (XWListItem)
|
view = XWListItem.inflate( DictsActivity.this,
|
||||||
m_factory.inflate( R.layout.list_item, null );
|
DictsActivity.this );
|
||||||
view.setSelCB( DictsActivity.this );
|
|
||||||
|
|
||||||
int lang = (int)getGroupId( groupPosition );
|
int lang = (int)getGroupId( groupPosition );
|
||||||
DictAndLoc[] dals = DictLangCache.getDALsHaveLang( m_context,
|
DictAndLoc[] dals = DictLangCache.getDALsHaveLang( m_context,
|
||||||
|
@ -146,7 +145,7 @@ public class DictsActivity extends XWExpandableListActivity
|
||||||
view.setComment( m_locNames[loc.ordinal()] );
|
view.setComment( m_locNames[loc.ordinal()] );
|
||||||
view.cache( loc );
|
view.cache( loc );
|
||||||
} else {
|
} else {
|
||||||
view.setText( m_download );
|
view.setText( m_downloadStr );
|
||||||
}
|
}
|
||||||
|
|
||||||
addToCache( groupPosition, childPosition, view );
|
addToCache( groupPosition, childPosition, view );
|
||||||
|
@ -392,7 +391,7 @@ public class DictsActivity extends XWExpandableListActivity
|
||||||
|
|
||||||
m_factory = LayoutInflater.from( this );
|
m_factory = LayoutInflater.from( this );
|
||||||
|
|
||||||
m_download = getString( R.string.download_dicts );
|
m_downloadStr = getString( R.string.download_dicts );
|
||||||
|
|
||||||
setContentView( R.layout.dict_browse );
|
setContentView( R.layout.dict_browse );
|
||||||
m_expView = getExpandableListView();
|
m_expView = getExpandableListView();
|
||||||
|
|
|
@ -697,8 +697,7 @@ public class GameConfig extends XWActivity
|
||||||
|
|
||||||
boolean localGame = localOnlyGame();
|
boolean localGame = localOnlyGame();
|
||||||
for ( int ii = 0; ii < names.length; ++ii ) {
|
for ( int ii = 0; ii < names.length; ++ii ) {
|
||||||
final XWListItem view
|
final XWListItem view = XWListItem.inflate( this, null );
|
||||||
= (XWListItem)factory.inflate( R.layout.list_item, null );
|
|
||||||
view.setPosition( ii );
|
view.setPosition( ii );
|
||||||
view.setText( names[ii] );
|
view.setText( names[ii] );
|
||||||
if ( localGame && m_gi.players[ii].isLocal ) {
|
if ( localGame && m_gi.players[ii].isLocal ) {
|
||||||
|
@ -837,8 +836,7 @@ public class GameConfig extends XWActivity
|
||||||
LinearLayout phoneList =
|
LinearLayout phoneList =
|
||||||
(LinearLayout)findViewById(R.id.sms_phones);
|
(LinearLayout)findViewById(R.id.sms_phones);
|
||||||
for ( CommsAddrRec addr : m_remoteAddrs ) {
|
for ( CommsAddrRec addr : m_remoteAddrs ) {
|
||||||
XWListItem item =
|
XWListItem item = XWListItem.inflate( this, null );
|
||||||
(XWListItem)Utils.inflate( this, R.layout.list_item );
|
|
||||||
item.setText( addr.sms_phone );
|
item.setText( addr.sms_phone );
|
||||||
String name = Utils.phoneToContact( this, addr.sms_phone,
|
String name = Utils.phoneToContact( this, addr.sms_phone,
|
||||||
false );
|
false );
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
|
|
||||||
package org.eehouse.android.xw4;
|
package org.eehouse.android.xw4;
|
||||||
|
|
||||||
|
import android.view.ViewGroup;
|
||||||
import android.widget.ListView;
|
import android.widget.ListView;
|
||||||
import android.app.AlertDialog;
|
import android.app.AlertDialog;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
@ -34,13 +35,16 @@ import android.widget.AdapterView.OnItemSelectedListener;
|
||||||
import android.widget.AdapterView;
|
import android.widget.AdapterView;
|
||||||
import android.widget.ArrayAdapter;
|
import android.widget.ArrayAdapter;
|
||||||
import android.widget.Spinner;
|
import android.widget.Spinner;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashSet;
|
||||||
|
|
||||||
import junit.framework.Assert;
|
import junit.framework.Assert;
|
||||||
|
|
||||||
import org.eehouse.android.xw4.DlgDelegate.Action;
|
import org.eehouse.android.xw4.DlgDelegate.Action;
|
||||||
|
import org.eehouse.android.xw4.jni.GameSummary;
|
||||||
|
|
||||||
public class StudyList extends XWListActivity
|
public class StudyList extends XWListActivity
|
||||||
implements OnItemSelectedListener {
|
implements OnItemSelectedListener, SelectableItem {
|
||||||
|
|
||||||
public static final int NO_LANG = -1;
|
public static final int NO_LANG = -1;
|
||||||
|
|
||||||
|
@ -50,7 +54,11 @@ public class StudyList extends XWListActivity
|
||||||
private View m_pickView; // LinearLayout, actually
|
private View m_pickView; // LinearLayout, actually
|
||||||
private int[] m_langCodes;
|
private int[] m_langCodes;
|
||||||
private String[] m_words;
|
private String[] m_words;
|
||||||
private int m_position;
|
private HashSet<Integer> m_checkeds;
|
||||||
|
private int m_langPosition;
|
||||||
|
private SLWordsAdapter<String> m_adapter;
|
||||||
|
private ListView m_list;
|
||||||
|
private CharSequence m_origTitle;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate( Bundle savedInstanceState )
|
protected void onCreate( Bundle savedInstanceState )
|
||||||
|
@ -58,9 +66,11 @@ public class StudyList extends XWListActivity
|
||||||
super.onCreate( savedInstanceState );
|
super.onCreate( savedInstanceState );
|
||||||
|
|
||||||
setContentView( R.layout.studylist );
|
setContentView( R.layout.studylist );
|
||||||
|
m_list = (ListView)findViewById( android.R.id.list );
|
||||||
|
|
||||||
m_spinner = (Spinner)findViewById( R.id.pick_lang_spinner );
|
m_spinner = (Spinner)findViewById( R.id.pick_lang_spinner );
|
||||||
m_pickView = findViewById( R.id.pick_lang );
|
m_pickView = findViewById( R.id.pick_lang );
|
||||||
|
|
||||||
initOrFinish( getIntent() );
|
initOrFinish( getIntent() );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -90,6 +100,20 @@ public class StudyList extends XWListActivity
|
||||||
showConfirmThen( R.string.confirm_studylist_clear,
|
showConfirmThen( R.string.confirm_studylist_clear,
|
||||||
Action.SL_CLEAR_ACTION );
|
Action.SL_CLEAR_ACTION );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case R.id.select_all:
|
||||||
|
for ( int ii = 0; ii < m_words.length; ++ii ) {
|
||||||
|
m_checkeds.add( ii );
|
||||||
|
}
|
||||||
|
makeAdapter();
|
||||||
|
setTitleBar();
|
||||||
|
break;
|
||||||
|
case R.id.deselect_all:
|
||||||
|
m_checkeds.clear();
|
||||||
|
makeAdapter();
|
||||||
|
setTitleBar();
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
handled = false;
|
handled = false;
|
||||||
}
|
}
|
||||||
|
@ -105,7 +129,7 @@ public class StudyList extends XWListActivity
|
||||||
if ( AlertDialog.BUTTON_POSITIVE == which ) {
|
if ( AlertDialog.BUTTON_POSITIVE == which ) {
|
||||||
switch ( action ) {
|
switch ( action ) {
|
||||||
case SL_CLEAR_ACTION:
|
case SL_CLEAR_ACTION:
|
||||||
DBUtils.studyListClear( this, m_langCodes[m_position] );
|
DBUtils.studyListClear( this, m_langCodes[m_langPosition] );
|
||||||
initOrFinish( null );
|
initOrFinish( null );
|
||||||
break;
|
break;
|
||||||
case SL_COPY_ACTION:
|
case SL_COPY_ACTION:
|
||||||
|
@ -127,7 +151,7 @@ public class StudyList extends XWListActivity
|
||||||
public void onListItemClick( ListView lv, View view, int position, long id )
|
public void onListItemClick( ListView lv, View view, int position, long id )
|
||||||
{
|
{
|
||||||
String[] words = { m_words[position] };
|
String[] words = { m_words[position] };
|
||||||
launchLookup( words, m_langCodes[m_position], true );
|
launchLookup( words, m_langCodes[m_langPosition], true );
|
||||||
}
|
}
|
||||||
|
|
||||||
//////////////////////////////////////////////////
|
//////////////////////////////////////////////////
|
||||||
|
@ -136,30 +160,60 @@ public class StudyList extends XWListActivity
|
||||||
public void onItemSelected( AdapterView<?> parent, View view,
|
public void onItemSelected( AdapterView<?> parent, View view,
|
||||||
int position, long id )
|
int position, long id )
|
||||||
{
|
{
|
||||||
m_position = position;
|
m_langPosition = position;
|
||||||
loadList();
|
loadList(); // because language has changed
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onNothingSelected( AdapterView<?> parent )
|
public void onNothingSelected( AdapterView<?> parent )
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//////////////////////////////////////////////////
|
||||||
|
// SelectableItem interface
|
||||||
|
//////////////////////////////////////////////////
|
||||||
|
public void itemClicked( SelectableItem.LongClickHandler clicked,
|
||||||
|
GameSummary summary )
|
||||||
|
{
|
||||||
|
Assert.assertTrue( clicked instanceof XWListItem );
|
||||||
|
m_checkeds.add( ((XWListItem)clicked).getPosition() );
|
||||||
|
}
|
||||||
|
|
||||||
|
public void itemToggled( SelectableItem.LongClickHandler toggled,
|
||||||
|
boolean selected )
|
||||||
|
{
|
||||||
|
Assert.assertTrue( toggled instanceof XWListItem );
|
||||||
|
int position = ((XWListItem)toggled).getPosition();
|
||||||
|
if ( selected ) {
|
||||||
|
m_checkeds.add( position );
|
||||||
|
} else {
|
||||||
|
m_checkeds.remove( position );
|
||||||
|
}
|
||||||
|
setTitleBar();
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean getSelected( SelectableItem.LongClickHandler obj )
|
||||||
|
{
|
||||||
|
Assert.assertTrue( obj instanceof XWListItem );
|
||||||
|
return m_checkeds.contains( ((XWListItem)obj).getPosition() );
|
||||||
|
}
|
||||||
|
|
||||||
private void loadList()
|
private void loadList()
|
||||||
{
|
{
|
||||||
int lang = m_langCodes[m_position];
|
int lang = m_langCodes[m_langPosition];
|
||||||
m_words = DBUtils.studyListWords( this, lang );
|
m_words = DBUtils.studyListWords( this, lang );
|
||||||
ArrayAdapter<String> adapter = new ArrayAdapter<String>
|
m_checkeds = new HashSet<Integer>();
|
||||||
( this, android.R.layout.simple_list_item_1 );
|
|
||||||
for ( String word : m_words ) {
|
|
||||||
adapter.add( word );
|
|
||||||
}
|
|
||||||
// adapter.sort();
|
|
||||||
|
|
||||||
setListAdapter( adapter );
|
makeAdapter();
|
||||||
|
|
||||||
String langName = DictLangCache.getLangNames( this )[lang];
|
String langName = DictLangCache.getLangNames( this )[lang];
|
||||||
String title = getString( R.string.studylist_titlef, langName );
|
m_origTitle = getString( R.string.studylist_titlef, langName );
|
||||||
setTitle( title );
|
setTitleBar();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void makeAdapter()
|
||||||
|
{
|
||||||
|
m_adapter = new SLWordsAdapter<String>( this, 0, m_words );
|
||||||
|
setListAdapter( m_adapter );
|
||||||
}
|
}
|
||||||
|
|
||||||
private void initOrFinish( Intent startIntent )
|
private void initOrFinish( Intent startIntent )
|
||||||
|
@ -169,7 +223,7 @@ public class StudyList extends XWListActivity
|
||||||
finish();
|
finish();
|
||||||
} else if ( 1 == m_langCodes.length ) {
|
} else if ( 1 == m_langCodes.length ) {
|
||||||
m_pickView.setVisibility( View.GONE );
|
m_pickView.setVisibility( View.GONE );
|
||||||
m_position = 0;
|
m_langPosition = 0;
|
||||||
loadList();
|
loadList();
|
||||||
} else {
|
} else {
|
||||||
int startLang = NO_LANG;
|
int startLang = NO_LANG;
|
||||||
|
@ -202,6 +256,19 @@ public class StudyList extends XWListActivity
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void setTitleBar()
|
||||||
|
{
|
||||||
|
CharSequence newTitle;
|
||||||
|
int nSels = m_checkeds.size();
|
||||||
|
DbgUtils.logf( "setTitleBar: nSels=%d", nSels );
|
||||||
|
if ( 0 == nSels ) {
|
||||||
|
newTitle = m_origTitle;
|
||||||
|
} else {
|
||||||
|
newTitle = getString( R.string.sel_wordsf, nSels );
|
||||||
|
}
|
||||||
|
setTitle( newTitle );
|
||||||
|
}
|
||||||
|
|
||||||
public static void launchOrAlert( Context context, int lang,
|
public static void launchOrAlert( Context context, int lang,
|
||||||
DlgDelegate.HasDlgDelegate dlg )
|
DlgDelegate.HasDlgDelegate dlg )
|
||||||
{
|
{
|
||||||
|
@ -225,4 +292,29 @@ public class StudyList extends XWListActivity
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private class SLWordsAdapter<String> extends ArrayAdapter<String> {
|
||||||
|
// public SLWordsAdapter()
|
||||||
|
// {
|
||||||
|
// super( m_words.length );
|
||||||
|
// }
|
||||||
|
|
||||||
|
public SLWordsAdapter( Context context, int ignored, String[] strings) {
|
||||||
|
super( context, ignored, strings );
|
||||||
|
}
|
||||||
|
|
||||||
|
public SLWordsAdapter( Context context, int resource ) {
|
||||||
|
super( context, resource );
|
||||||
|
}
|
||||||
|
|
||||||
|
public View getView( int position, View convertView,
|
||||||
|
ViewGroup parent ) {
|
||||||
|
XWListItem item = XWListItem.inflate( StudyList.this, StudyList.this );
|
||||||
|
item.setPosition( position );
|
||||||
|
item.setText( m_words[position] );
|
||||||
|
item.setSelected( m_checkeds.contains(position) );
|
||||||
|
DbgUtils.logf( "getView(position=%d) => %H", position, item );
|
||||||
|
return item;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,10 +28,12 @@ import android.view.View;
|
||||||
import android.widget.ImageButton;
|
import android.widget.ImageButton;
|
||||||
import android.widget.LinearLayout;
|
import android.widget.LinearLayout;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
import android.widget.CheckBox;
|
||||||
|
|
||||||
|
import junit.framework.Assert;
|
||||||
|
|
||||||
public class XWListItem extends LinearLayout
|
public class XWListItem extends LinearLayout
|
||||||
implements SelectableItem.LongClickHandler {
|
implements SelectableItem.LongClickHandler, View.OnClickListener {
|
||||||
private int m_position;
|
private int m_position;
|
||||||
private Context m_context;
|
private Context m_context;
|
||||||
private Object m_cached;
|
private Object m_cached;
|
||||||
|
@ -39,6 +41,7 @@ public class XWListItem extends LinearLayout
|
||||||
private Drawable m_origDrawable;
|
private Drawable m_origDrawable;
|
||||||
private boolean m_selected = false;
|
private boolean m_selected = false;
|
||||||
private SelectableItem m_selCb;
|
private SelectableItem m_selCb;
|
||||||
|
private CheckBox m_checkbox;
|
||||||
|
|
||||||
public interface DeleteCallback {
|
public interface DeleteCallback {
|
||||||
void deleteCalled( XWListItem item );
|
void deleteCalled( XWListItem item );
|
||||||
|
@ -49,6 +52,15 @@ public class XWListItem extends LinearLayout
|
||||||
m_context = cx;
|
m_context = cx;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onFinishInflate()
|
||||||
|
{
|
||||||
|
super.onFinishInflate();
|
||||||
|
m_checkbox = (CheckBox)findViewById( R.id.checkbox );
|
||||||
|
Assert.assertNotNull( m_checkbox );
|
||||||
|
m_checkbox.setOnClickListener( this );
|
||||||
|
}
|
||||||
|
|
||||||
public int getPosition() { return m_position; }
|
public int getPosition() { return m_position; }
|
||||||
public void setPosition( int indx ) { m_position = indx; }
|
public void setPosition( int indx ) { m_position = indx; }
|
||||||
|
|
||||||
|
@ -86,9 +98,10 @@ public class XWListItem extends LinearLayout
|
||||||
button.setVisibility( View.VISIBLE );
|
button.setVisibility( View.VISIBLE );
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setSelCB( SelectableItem selCB )
|
private void setSelCB( SelectableItem selCB )
|
||||||
{
|
{
|
||||||
m_selCb = selCB;
|
m_selCb = selCB;
|
||||||
|
m_checkbox.setVisibility( null == selCB ? View.GONE : View.VISIBLE );
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setSelected( boolean selected )
|
public void setSelected( boolean selected )
|
||||||
|
@ -129,6 +142,14 @@ public class XWListItem extends LinearLayout
|
||||||
toggleSelected();
|
toggleSelected();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// View.OnClickListener interface
|
||||||
|
public void onClick( View view )
|
||||||
|
{
|
||||||
|
if ( m_checkbox == view ) {
|
||||||
|
setSelected( m_checkbox.isChecked() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void toggleSelected()
|
private void toggleSelected()
|
||||||
{
|
{
|
||||||
m_selected = !m_selected;
|
m_selected = !m_selected;
|
||||||
|
@ -138,6 +159,15 @@ public class XWListItem extends LinearLayout
|
||||||
} else {
|
} else {
|
||||||
setBackgroundDrawable( m_origDrawable );
|
setBackgroundDrawable( m_origDrawable );
|
||||||
}
|
}
|
||||||
|
m_checkbox.setChecked( m_selected );
|
||||||
|
|
||||||
m_selCb.itemToggled( this, m_selected );
|
m_selCb.itemToggled( this, m_selected );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static XWListItem inflate( Context context, SelectableItem selCB )
|
||||||
|
{
|
||||||
|
XWListItem item = (XWListItem)Utils.inflate( context, R.layout.list_item );
|
||||||
|
item.setSelCB( selCB );
|
||||||
|
return item;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue