mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-24 07:58:34 +01:00
remember last-used radio and start with it next time
Saves a step if you generally create games the same way most of the time. Required reordering alert init.
This commit is contained in:
parent
357897661e
commit
ddd5f7b978
2 changed files with 41 additions and 15 deletions
|
@ -919,7 +919,6 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
// String[] names = XwJNI.kplr_getPlayers();
|
// String[] names = XwJNI.kplr_getPlayers();
|
||||||
final NewWithKnowns view = (NewWithKnowns)
|
final NewWithKnowns view = (NewWithKnowns)
|
||||||
LocUtils.inflate( m_activity, R.layout.new_game_with_knowns );
|
LocUtils.inflate( m_activity, R.layout.new_game_with_knowns );
|
||||||
view.configure( standalone, GameUtils.makeDefaultName( m_activity ) );
|
|
||||||
AlertDialog.Builder ab = makeAlertBuilder()
|
AlertDialog.Builder ab = makeAlertBuilder()
|
||||||
.setView( view )
|
.setView( view )
|
||||||
.setTitle( standalone ? R.string.new_game : R.string.new_game_networked )
|
.setTitle( standalone ? R.string.new_game : R.string.new_game_networked )
|
||||||
|
@ -964,17 +963,24 @@ public class GamesListDelegate extends ListDelegateBase
|
||||||
}
|
}
|
||||||
|
|
||||||
final AlertDialog dialog = ab.create();
|
final AlertDialog dialog = ab.create();
|
||||||
view.setCallback( new NewWithKnowns.ButtonChangeListener() {
|
|
||||||
@Override
|
dialog.setOnShowListener(new DialogInterface.OnShowListener() {
|
||||||
public void onNewButtonText( String txt ) {
|
@Override
|
||||||
Button button = dialog.getButton( DialogInterface.BUTTON_POSITIVE );
|
public void onShow( DialogInterface diface ) {
|
||||||
if ( null != button ) {
|
view.setCallback( new NewWithKnowns.ButtonChangeListener() {
|
||||||
button.setText( txt );
|
@Override
|
||||||
} else {
|
public void onNewButtonText( String txt ) {
|
||||||
Log.e( TAG, "Button still null" );
|
Button button = dialog.getButton( DialogInterface.BUTTON_POSITIVE );
|
||||||
}
|
if ( null != button ) {
|
||||||
}
|
button.setText( txt );
|
||||||
} );
|
} else {
|
||||||
|
Assert.failDbg();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} );
|
||||||
|
view.configure( standalone, GameUtils.makeDefaultName( m_activity ) );
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
return dialog;
|
return dialog;
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,6 +27,7 @@ import android.widget.AdapterView.OnItemSelectedListener;
|
||||||
import android.widget.AdapterView;
|
import android.widget.AdapterView;
|
||||||
import android.widget.ArrayAdapter;
|
import android.widget.ArrayAdapter;
|
||||||
import android.widget.LinearLayout;
|
import android.widget.LinearLayout;
|
||||||
|
import android.widget.RadioButton;
|
||||||
import android.widget.RadioGroup;
|
import android.widget.RadioGroup;
|
||||||
import android.widget.Spinner;
|
import android.widget.Spinner;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
@ -39,6 +40,8 @@ public class NewWithKnowns extends LinearLayout
|
||||||
{
|
{
|
||||||
private static final String TAG = NewWithKnowns.class.getSimpleName();
|
private static final String TAG = NewWithKnowns.class.getSimpleName();
|
||||||
private static final String KP_NAME_KEY = TAG + "/kp_last_name";
|
private static final String KP_NAME_KEY = TAG + "/kp_last_name";
|
||||||
|
private static final String KP_PREVSOLO_KEY = TAG + "/kp_prev_solo";
|
||||||
|
private static final String KP_PREVNET_KEY = TAG + "/kp_prev_net";
|
||||||
|
|
||||||
public interface ButtonChangeListener {
|
public interface ButtonChangeListener {
|
||||||
void onNewButtonText( String txt );
|
void onNewButtonText( String txt );
|
||||||
|
@ -68,15 +71,16 @@ public class NewWithKnowns extends LinearLayout
|
||||||
|
|
||||||
void configure( boolean standalone, String gameName )
|
void configure( boolean standalone, String gameName )
|
||||||
{
|
{
|
||||||
|
Context context = getContext();
|
||||||
mStandalone = standalone;
|
mStandalone = standalone;
|
||||||
boolean hasKnowns = !standalone && XwJNI.hasKnownPlayers();
|
boolean hasKnowns = !standalone && XwJNI.hasKnownPlayers();
|
||||||
int[] toHide;
|
int[] toHide;
|
||||||
if ( hasKnowns ) {
|
if ( hasKnowns ) {
|
||||||
String[] knowns = XwJNI.kplr_getPlayers();
|
String[] knowns = XwJNI.kplr_getPlayers();
|
||||||
mCurKnown = DBUtils.getStringFor( getContext(), KP_NAME_KEY,
|
mCurKnown = DBUtils.getStringFor( context, KP_NAME_KEY,
|
||||||
knowns[0] );
|
knowns[0] );
|
||||||
ArrayAdapter<String> adapter = new
|
ArrayAdapter<String> adapter = new
|
||||||
ArrayAdapter<String>( getContext(),
|
ArrayAdapter<String>( context,
|
||||||
android.R.layout.simple_spinner_item,
|
android.R.layout.simple_spinner_item,
|
||||||
knowns );
|
knowns );
|
||||||
adapter.setDropDownViewResource( android.R.layout
|
adapter.setDropDownViewResource( android.R.layout
|
||||||
|
@ -108,14 +112,27 @@ public class NewWithKnowns extends LinearLayout
|
||||||
|
|
||||||
RadioGroup group = (RadioGroup)findViewById( R.id.group );
|
RadioGroup group = (RadioGroup)findViewById( R.id.group );
|
||||||
group.setOnCheckedChangeListener( this );
|
group.setOnCheckedChangeListener( this );
|
||||||
|
|
||||||
|
String key = standalone ? KP_PREVSOLO_KEY : KP_PREVNET_KEY;
|
||||||
|
int lastSet = DBUtils.getIntFor( context, key, 0 );
|
||||||
|
if ( lastSet != 0 ) {
|
||||||
|
// Let's made sure it's still a RadioButton. Ids are generated by
|
||||||
|
// the build system and can change. Passing a non-radiobutton id
|
||||||
|
// to check() still calls onCheckedChanged() etc.
|
||||||
|
View view = findViewById( lastSet );
|
||||||
|
if ( null != view && view instanceof RadioButton ) {
|
||||||
|
group.check( lastSet );
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void onButtonPressed( ButtonCallbacks procs )
|
void onButtonPressed( ButtonCallbacks procs )
|
||||||
{
|
{
|
||||||
|
Context context = getContext();
|
||||||
String gameName = gameName();
|
String gameName = gameName();
|
||||||
switch ( mCurRadio ) {
|
switch ( mCurRadio ) {
|
||||||
case R.id.radio_known:
|
case R.id.radio_known:
|
||||||
DBUtils.setStringFor( getContext(), KP_NAME_KEY, mCurKnown );
|
DBUtils.setStringFor( context, KP_NAME_KEY, mCurKnown );
|
||||||
procs.onUseKnown( mCurKnown, gameName );
|
procs.onUseKnown( mCurKnown, gameName );
|
||||||
break;
|
break;
|
||||||
case R.id.radio_unknown:
|
case R.id.radio_unknown:
|
||||||
|
@ -129,6 +146,9 @@ public class NewWithKnowns extends LinearLayout
|
||||||
Assert.failDbg();
|
Assert.failDbg();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
String key = mStandalone ? KP_PREVSOLO_KEY : KP_PREVNET_KEY;
|
||||||
|
DBUtils.setIntFor( context, key, mCurRadio );
|
||||||
}
|
}
|
||||||
|
|
||||||
private String gameName()
|
private String gameName()
|
||||||
|
|
Loading…
Add table
Reference in a new issue