mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-24 07:58:34 +01:00
add hint explaining new tap-on-pending-words feature
And bring back another BoardCanvas hint that had been commented out.
This commit is contained in:
parent
660cfa83a3
commit
4db2fd229b
3 changed files with 39 additions and 16 deletions
|
@ -1,7 +1,7 @@
|
||||||
/* -*- compile-command: "find-and-gradle.sh inXw4dDeb"; -*- */
|
/* -*- compile-command: "find-and-gradle.sh inXw4dDeb"; -*- */
|
||||||
/*
|
/*
|
||||||
* Copyright 2009 - 2013 by Eric House (xwords@eehouse.org). All
|
* Copyright 2009 - 2019 by Eric House (xwords@eehouse.org). All rights
|
||||||
* rights reserved.
|
* reserved.
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or
|
* This program is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License as
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
@ -31,6 +31,8 @@ import android.graphics.RectF;
|
||||||
import android.graphics.drawable.BitmapDrawable;
|
import android.graphics.drawable.BitmapDrawable;
|
||||||
import android.graphics.drawable.Drawable;
|
import android.graphics.drawable.Drawable;
|
||||||
|
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
import org.eehouse.android.xw4.jni.BoardDims;
|
import org.eehouse.android.xw4.jni.BoardDims;
|
||||||
import org.eehouse.android.xw4.jni.CommonPrefs;
|
import org.eehouse.android.xw4.jni.CommonPrefs;
|
||||||
|
@ -88,6 +90,7 @@ public class BoardCanvas extends Canvas implements DrawCtx {
|
||||||
protected String[] m_dictChars;
|
protected String[] m_dictChars;
|
||||||
private boolean m_hasSmallScreen;
|
private boolean m_hasSmallScreen;
|
||||||
private int m_backgroundUsed = 0x00000000;
|
private int m_backgroundUsed = 0x00000000;
|
||||||
|
private int mPendingCount;
|
||||||
|
|
||||||
// FontDims: exists to translate space available to the largest
|
// FontDims: exists to translate space available to the largest
|
||||||
// font we can draw within that space taking advantage of our use
|
// font we can draw within that space taking advantage of our use
|
||||||
|
@ -382,6 +385,7 @@ public class BoardCanvas extends Canvas implements DrawCtx {
|
||||||
bonusStr = m_bonusSummaries[bonus];
|
bonusStr = m_bonusSummaries[bonus];
|
||||||
}
|
}
|
||||||
} else if ( pending ) {
|
} else if ( pending ) {
|
||||||
|
++mPendingCount;
|
||||||
if ( darkOnLight() ) {
|
if ( darkOnLight() ) {
|
||||||
foreColor = WHITE;
|
foreColor = WHITE;
|
||||||
backColor = BLACK;
|
backColor = BLACK;
|
||||||
|
@ -425,7 +429,6 @@ public class BoardCanvas extends Canvas implements DrawCtx {
|
||||||
return canDraw;
|
return canDraw;
|
||||||
} // drawCell
|
} // drawCell
|
||||||
|
|
||||||
private boolean m_arrowHintShown = false;
|
|
||||||
public void drawBoardArrow( Rect rect, int bonus, boolean vert,
|
public void drawBoardArrow( Rect rect, int bonus, boolean vert,
|
||||||
int hintAtts, int flags )
|
int hintAtts, int flags )
|
||||||
{
|
{
|
||||||
|
@ -452,19 +455,7 @@ public class BoardCanvas extends Canvas implements DrawCtx {
|
||||||
arrow.setBounds( rect );
|
arrow.setBounds( rect );
|
||||||
arrow.draw( BoardCanvas.this );
|
arrow.draw( BoardCanvas.this );
|
||||||
|
|
||||||
if ( !m_arrowHintShown ) {
|
postNAHint( R.string.not_again_arrow, R.string.key_notagain_arrow );
|
||||||
m_arrowHintShown = true;
|
|
||||||
// Handler handler = getHandler();
|
|
||||||
// if ( null != handler ) {
|
|
||||||
// handler.post( new Runnable() {
|
|
||||||
// public void run() {
|
|
||||||
// m_parent.
|
|
||||||
// showNotAgainDlgThen( R.string.not_again_arrow,
|
|
||||||
// R.string.
|
|
||||||
// key_notagain_arrow );
|
|
||||||
// } } );
|
|
||||||
// }
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean trayBegin( Rect rect, int owner, int score )
|
public boolean trayBegin( Rect rect, int owner, int score )
|
||||||
|
@ -543,6 +534,12 @@ public class BoardCanvas extends Canvas implements DrawCtx {
|
||||||
int xx = rect.left + rect.width() - 1;
|
int xx = rect.left + rect.width() - 1;
|
||||||
drawLine( xx, rect.top, xx, rect.top + rect.height(),
|
drawLine( xx, rect.top, xx, rect.top + rect.height(),
|
||||||
m_strokePaint );
|
m_strokePaint );
|
||||||
|
|
||||||
|
if ( mPendingCount > 0 ) {
|
||||||
|
mPendingCount = 0;
|
||||||
|
postNAHint( R.string.not_again_longtap_lookup,
|
||||||
|
R.string.key_na_longtap_lookup );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -886,4 +883,23 @@ public class BoardCanvas extends Canvas implements DrawCtx {
|
||||||
return m_tileStrokePaint;
|
return m_tileStrokePaint;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static Set<Integer> sShown = new HashSet<>();
|
||||||
|
private void postNAHint( final int msgID, final int keyID )
|
||||||
|
{
|
||||||
|
if ( !sShown.contains( keyID ) ) {
|
||||||
|
sShown.add( keyID );
|
||||||
|
|
||||||
|
if ( m_activity instanceof XWActivity ) {
|
||||||
|
final XWActivity activity = (XWActivity)m_activity;
|
||||||
|
|
||||||
|
activity.runOnUiThread( new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
activity.makeNotAgainBuilder( msgID, keyID )
|
||||||
|
.show();
|
||||||
|
}
|
||||||
|
} );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -145,6 +145,7 @@
|
||||||
<string name="key_na_comms_relay">key_na_comms_relay</string>
|
<string name="key_na_comms_relay">key_na_comms_relay</string>
|
||||||
<string name="key_na_bt_badproto">key_na_bt_badproto</string>
|
<string name="key_na_bt_badproto">key_na_bt_badproto</string>
|
||||||
<string name="key_na_sms_banned">key_na_sms_banned</string>
|
<string name="key_na_sms_banned">key_na_sms_banned</string>
|
||||||
|
<string name="key_na_longtap_lookup">key_na_longtap_lookup</string>
|
||||||
|
|
||||||
<!-- Nor is my email address -->
|
<!-- Nor is my email address -->
|
||||||
<string name="email_author_email">xwords@eehouse.org</string>
|
<string name="email_author_email">xwords@eehouse.org</string>
|
||||||
|
|
|
@ -2850,4 +2850,10 @@
|
||||||
<string name="relay_poll_name_no_polling">FCM only: no polling</string>
|
<string name="relay_poll_name_no_polling">FCM only: no polling</string>
|
||||||
<string name="relay_poll_name_both">Default: mix polling and FCM</string>
|
<string name="relay_poll_name_both">Default: mix polling and FCM</string>
|
||||||
|
|
||||||
|
<string name="not_again_longtap_lookup">You can look up words BEFORE
|
||||||
|
they\'re committed as moves -- by long-tapping, same as committed
|
||||||
|
words.\n\nUse this feature to check the validity of words you\'re
|
||||||
|
thinking of playing, or to look up an unfamiliar word provided as a
|
||||||
|
hint.</string>
|
||||||
|
|
||||||
</resources>
|
</resources>
|
||||||
|
|
Loading…
Add table
Reference in a new issue