mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-20 22:26:54 +01:00
update to work with robot-smartness changes. At this point the UI's
unchanged and I'm trying to mimic the old per-game setting using the new per-robot setting internally. Still need to change the UI to allow move than just a boolean choice.
This commit is contained in:
parent
a656bb8f0c
commit
ceab787cdd
3 changed files with 43 additions and 14 deletions
|
@ -330,7 +330,7 @@ public class GameConfig extends XWActivity
|
||||||
};
|
};
|
||||||
check.setOnCheckedChangeListener( lstnr );
|
check.setOnCheckedChangeListener( lstnr );
|
||||||
|
|
||||||
Utils.setChecked( m_curDialog, R.id.robot_check, lp.isRobot );
|
Utils.setChecked( m_curDialog, R.id.robot_check, lp.isRobot() );
|
||||||
Utils.setChecked( m_curDialog, R.id.remote_check, ! lp.isLocal );
|
Utils.setChecked( m_curDialog, R.id.remote_check, ! lp.isLocal );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -340,7 +340,7 @@ public class GameConfig extends XWActivity
|
||||||
lp.name = Utils.getText( m_curDialog, R.id.player_name_edit );
|
lp.name = Utils.getText( m_curDialog, R.id.player_name_edit );
|
||||||
lp.password = Utils.getText( m_curDialog, R.id.password_edit );
|
lp.password = Utils.getText( m_curDialog, R.id.password_edit );
|
||||||
|
|
||||||
lp.isRobot = Utils.getChecked( m_curDialog, R.id.robot_check );
|
lp.setIsRobot( Utils.getChecked( m_curDialog, R.id.robot_check ) );
|
||||||
lp.isLocal = !Utils.getChecked( m_curDialog, R.id.remote_check );
|
lp.isLocal = !Utils.getChecked( m_curDialog, R.id.remote_check );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -459,7 +459,7 @@ public class GameConfig extends XWActivity
|
||||||
check.setOnCheckedChangeListener( lstnr );
|
check.setOnCheckedChangeListener( lstnr );
|
||||||
Utils.setChecked( this, R.id.use_timer, m_gi.timerEnabled );
|
Utils.setChecked( this, R.id.use_timer, m_gi.timerEnabled );
|
||||||
|
|
||||||
Utils.setChecked( this, R.id.smart_robot, 0 < m_gi.robotSmartness );
|
Utils.setChecked( this, R.id.smart_robot, m_gi.getRobotsAreSmart() );
|
||||||
|
|
||||||
String fmt = getString( m_notNetworkedGame ?
|
String fmt = getString( m_notNetworkedGame ?
|
||||||
R.string.title_game_configf
|
R.string.title_game_configf
|
||||||
|
@ -831,8 +831,7 @@ public class GameConfig extends XWActivity
|
||||||
m_gi.timerEnabled = Utils.getChecked( this, R.id.use_timer );
|
m_gi.timerEnabled = Utils.getChecked( this, R.id.use_timer );
|
||||||
m_gi.gameSeconds = 60 * m_gi.nPlayers *
|
m_gi.gameSeconds = 60 * m_gi.nPlayers *
|
||||||
Utils.getInt( this, R.id.timer_minutes_edit );
|
Utils.getInt( this, R.id.timer_minutes_edit );
|
||||||
m_gi.robotSmartness
|
m_gi.setRobotsAreSmart( Utils.getChecked( this, R.id.smart_robot ) );
|
||||||
= Utils.getChecked( this, R.id.smart_robot ) ? 1 : 0;
|
|
||||||
|
|
||||||
int position = m_phoniesSpinner.getSelectedItemPosition();
|
int position = m_phoniesSpinner.getSelectedItemPosition();
|
||||||
m_gi.phoniesAction = CurGameInfo.XWPhoniesChoice.values()[position];
|
m_gi.phoniesAction = CurGameInfo.XWPhoniesChoice.values()[position];
|
||||||
|
|
|
@ -49,13 +49,13 @@ public class CurGameInfo {
|
||||||
public boolean timerEnabled;
|
public boolean timerEnabled;
|
||||||
public boolean allowPickTiles;
|
public boolean allowPickTiles;
|
||||||
public boolean allowHintRect;
|
public boolean allowHintRect;
|
||||||
public int robotSmartness;
|
|
||||||
public XWPhoniesChoice phoniesAction;
|
public XWPhoniesChoice phoniesAction;
|
||||||
public boolean confirmBTConnect; /* only used for BT */
|
public boolean confirmBTConnect; /* only used for BT */
|
||||||
|
|
||||||
// private int[] m_visiblePlayers;
|
// private int[] m_visiblePlayers;
|
||||||
// private int m_nVisiblePlayers;
|
// private int m_nVisiblePlayers;
|
||||||
private boolean m_inProgress;
|
private boolean m_inProgress;
|
||||||
|
private boolean m_smart;
|
||||||
|
|
||||||
public CurGameInfo( Context context )
|
public CurGameInfo( Context context )
|
||||||
{
|
{
|
||||||
|
@ -79,7 +79,6 @@ public class CurGameInfo {
|
||||||
timerEnabled = CommonPrefs.getDefaultTimerEnabled( context );
|
timerEnabled = CommonPrefs.getDefaultTimerEnabled( context );
|
||||||
allowPickTiles = false;
|
allowPickTiles = false;
|
||||||
allowHintRect = false;
|
allowHintRect = false;
|
||||||
robotSmartness = 1;
|
|
||||||
|
|
||||||
// Always create MAX_NUM_PLAYERS so jni code doesn't ever have
|
// Always create MAX_NUM_PLAYERS so jni code doesn't ever have
|
||||||
// to cons up a LocalPlayer instance.
|
// to cons up a LocalPlayer instance.
|
||||||
|
@ -90,7 +89,7 @@ public class CurGameInfo {
|
||||||
if ( isNetworked ) {
|
if ( isNetworked ) {
|
||||||
players[1].isLocal = false;
|
players[1].isLocal = false;
|
||||||
} else {
|
} else {
|
||||||
players[0].isRobot = true;
|
players[0].setIsRobot( 1 );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -110,7 +109,6 @@ public class CurGameInfo {
|
||||||
timerEnabled = src.timerEnabled;
|
timerEnabled = src.timerEnabled;
|
||||||
allowPickTiles = src.allowPickTiles;
|
allowPickTiles = src.allowPickTiles;
|
||||||
allowHintRect = src.allowHintRect;
|
allowHintRect = src.allowHintRect;
|
||||||
robotSmartness = src.robotSmartness;
|
|
||||||
|
|
||||||
int ii;
|
int ii;
|
||||||
for ( ii = 0; ii < MAX_NUM_PLAYERS; ++ii ) {
|
for ( ii = 0; ii < MAX_NUM_PLAYERS; ++ii ) {
|
||||||
|
@ -133,6 +131,21 @@ public class CurGameInfo {
|
||||||
m_inProgress = inProgress;
|
m_inProgress = inProgress;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean getRobotsAreSmart()
|
||||||
|
{
|
||||||
|
return m_smart;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setRobotsAreSmart( boolean smart )
|
||||||
|
{
|
||||||
|
m_smart = smart;
|
||||||
|
for ( int ii = 0; ii < nPlayers; ++ii ) {
|
||||||
|
if ( players[ii].isRobot() ) {
|
||||||
|
players[ii].setIsRobot( smart ? 1 : 100 );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/** return true if any of the changes made would invalide a game
|
/** return true if any of the changes made would invalide a game
|
||||||
* in progress, i.e. require that it be restarted with the new
|
* in progress, i.e. require that it be restarted with the new
|
||||||
* params. E.g. changing a player to a robot is harmless for a
|
* params. E.g. changing a player to a robot is harmless for a
|
||||||
|
@ -152,7 +165,7 @@ public class CurGameInfo {
|
||||||
for ( int ii = 0; ii < nPlayers; ++ii ) {
|
for ( int ii = 0; ii < nPlayers; ++ii ) {
|
||||||
LocalPlayer me = players[ii];
|
LocalPlayer me = players[ii];
|
||||||
LocalPlayer him = other.players[ii];
|
LocalPlayer him = other.players[ii];
|
||||||
matter = me.isRobot != him.isRobot
|
matter = me.isRobot() != him.isRobot()
|
||||||
|| me.isLocal != him.isLocal
|
|| me.isLocal != him.isLocal
|
||||||
|| !me.name.equals( him.name );
|
|| !me.name.equals( him.name );
|
||||||
if ( matter ) {
|
if ( matter ) {
|
||||||
|
@ -198,7 +211,7 @@ public class CurGameInfo {
|
||||||
LocalPlayer lp = players[ii];
|
LocalPlayer lp = players[ii];
|
||||||
if ( lp.isLocal || serverRole == DeviceRole.SERVER_STANDALONE ) {
|
if ( lp.isLocal || serverRole == DeviceRole.SERVER_STANDALONE ) {
|
||||||
names[ii] = lp.name;
|
names[ii] = lp.name;
|
||||||
if ( lp.isRobot ) {
|
if ( lp.isRobot() ) {
|
||||||
names[ii] += " " + context.getString( R.string.robot_name );
|
names[ii] += " " + context.getString( R.string.robot_name );
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -22,18 +22,19 @@ package org.eehouse.android.xw4.jni;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import org.eehouse.android.xw4.R;
|
import org.eehouse.android.xw4.R;
|
||||||
|
import junit.framework.Assert;
|
||||||
|
|
||||||
public class LocalPlayer {
|
public class LocalPlayer {
|
||||||
public String name;
|
public String name;
|
||||||
public String password;
|
public String password;
|
||||||
public int secondsUsed;
|
public int secondsUsed;
|
||||||
public boolean isRobot;
|
public int robotIQ;
|
||||||
public boolean isLocal;
|
public boolean isLocal;
|
||||||
|
|
||||||
public LocalPlayer( Context context, int num )
|
public LocalPlayer( Context context, int num )
|
||||||
{
|
{
|
||||||
isLocal = true;
|
isLocal = true;
|
||||||
isRobot = false;
|
robotIQ = 0; // human
|
||||||
String fmt = context.getString( R.string.playerf );
|
String fmt = context.getString( R.string.playerf );
|
||||||
name = String.format( fmt, num + 1 );
|
name = String.format( fmt, num + 1 );
|
||||||
password = "";
|
password = "";
|
||||||
|
@ -42,7 +43,7 @@ public class LocalPlayer {
|
||||||
public LocalPlayer( final LocalPlayer src )
|
public LocalPlayer( final LocalPlayer src )
|
||||||
{
|
{
|
||||||
isLocal = src.isLocal;
|
isLocal = src.isLocal;
|
||||||
isRobot = src.isRobot;
|
robotIQ = src.robotIQ;
|
||||||
if ( null != src.name ) {
|
if ( null != src.name ) {
|
||||||
name = new String(src.name);
|
name = new String(src.name);
|
||||||
}
|
}
|
||||||
|
@ -51,5 +52,21 @@ public class LocalPlayer {
|
||||||
}
|
}
|
||||||
secondsUsed = src.secondsUsed;
|
secondsUsed = src.secondsUsed;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isRobot()
|
||||||
|
{
|
||||||
|
return robotIQ > 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setIsRobot( boolean isRobot )
|
||||||
|
{
|
||||||
|
robotIQ = isRobot ? 1 : 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setIsRobot( int iq )
|
||||||
|
{
|
||||||
|
Assert.assertTrue( iq > 0 );
|
||||||
|
robotIQ = iq;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue