mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-23 07:27:22 +01:00
use new board_drawSnapshot() from android
BoardCanvas wouldn't render anything without an associated dict via dictChanged()
This commit is contained in:
parent
7f513313b0
commit
8b142e4a56
5 changed files with 23 additions and 17 deletions
|
@ -976,6 +976,18 @@ Java_org_eehouse_android_xw4_jni_XwJNI_board_1draw
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
JNIEXPORT void JNICALL
|
||||||
|
Java_org_eehouse_android_xw4_jni_XwJNI_board_1drawSnapshot
|
||||||
|
( JNIEnv *env, jclass C, GamePtrType gamePtr, jobject jdraw, jint width,
|
||||||
|
jint height )
|
||||||
|
{
|
||||||
|
XWJNI_START();
|
||||||
|
DrawCtx* newDraw = makeDraw( MPPARM(mpool) &state->globalJNI->ti, jdraw );
|
||||||
|
board_drawSnapshot( state->game.board, newDraw, width, height );
|
||||||
|
destroyDraw( &newDraw );
|
||||||
|
XWJNI_END();
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef COMMON_LAYOUT
|
#ifdef COMMON_LAYOUT
|
||||||
JNIEXPORT void JNICALL
|
JNIEXPORT void JNICALL
|
||||||
Java_org_eehouse_android_xw4_jni_XwJNI_board_1figureLayout
|
Java_org_eehouse_android_xw4_jni_XwJNI_board_1figureLayout
|
||||||
|
|
|
@ -116,20 +116,19 @@
|
||||||
android:defaultValue="@string/game_summary_field_opponents"
|
android:defaultValue="@string/game_summary_field_opponents"
|
||||||
/>
|
/>
|
||||||
|
|
||||||
<CheckBoxPreference android:key="@string/key_enable_dualpane"
|
<CheckBoxPreference android:key="@string/key_hide_newgames"
|
||||||
android:title="@string/enable_dualpane_title"
|
android:title="@string/hide_newgames_title"
|
||||||
android:summary="@string/enable_dualpane_summary"
|
android:summary="@string/hide_newgames_summary"
|
||||||
android:defaultValue="false"
|
android:defaultValue="false"
|
||||||
/>
|
/>
|
||||||
|
|
||||||
<CheckBoxPreference android:key="@string/key_hide_title"
|
<CheckBoxPreference android:key="@string/key_hide_title"
|
||||||
android:title="@string/hide_title"
|
android:title="@string/hide_title"
|
||||||
android:summary="@string/hide_title_summary"
|
android:summary="@string/hide_title_summary"
|
||||||
android:defaultValue="false"
|
android:defaultValue="false"
|
||||||
/>
|
/>
|
||||||
<CheckBoxPreference android:key="@string/key_hide_newgames"
|
<CheckBoxPreference android:key="@string/key_enable_dualpane"
|
||||||
android:title="@string/hide_newgames_title"
|
android:title="@string/enable_dualpane_title"
|
||||||
android:summary="@string/hide_newgames_summary"
|
android:summary="@string/enable_dualpane_summary"
|
||||||
android:defaultValue="false"
|
android:defaultValue="false"
|
||||||
/>
|
/>
|
||||||
<CheckBoxPreference android:key="@string/key_show_arrow"
|
<CheckBoxPreference android:key="@string/key_show_arrow"
|
||||||
|
|
|
@ -391,15 +391,8 @@ public class GameUtils {
|
||||||
|
|
||||||
thumb = Bitmap.createBitmap( size, size,
|
thumb = Bitmap.createBitmap( size, size,
|
||||||
Bitmap.Config.ARGB_8888 );
|
Bitmap.Config.ARGB_8888 );
|
||||||
|
|
||||||
XwJNI.board_figureLayout( gamePtr, gi, 0, 0, size, size,
|
|
||||||
0, 0, 0, 20, 20, false, null );
|
|
||||||
|
|
||||||
ThumbCanvas canvas = new ThumbCanvas( context, thumb );
|
ThumbCanvas canvas = new ThumbCanvas( context, thumb );
|
||||||
XwJNI.board_setDraw( gamePtr, canvas );
|
XwJNI.board_drawSnapshot( gamePtr, canvas, size, size );
|
||||||
XwJNI.board_invalAll( gamePtr );
|
|
||||||
Assert.assertNotNull( gamePtr );
|
|
||||||
XwJNI.board_draw( gamePtr );
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return thumb;
|
return thumb;
|
||||||
|
|
|
@ -268,6 +268,8 @@ public class XwJNI {
|
||||||
public static native void board_setDraw( GamePtr gamePtr, DrawCtx draw );
|
public static native void board_setDraw( GamePtr gamePtr, DrawCtx draw );
|
||||||
public static native void board_invalAll( GamePtr gamePtr );
|
public static native void board_invalAll( GamePtr gamePtr );
|
||||||
public static native boolean board_draw( GamePtr gamePtr );
|
public static native boolean board_draw( GamePtr gamePtr );
|
||||||
|
public static native void board_drawSnapshot( GamePtr gamePtr, DrawCtx draw,
|
||||||
|
int width, int height );
|
||||||
|
|
||||||
// Only if COMMON_LAYOUT defined
|
// Only if COMMON_LAYOUT defined
|
||||||
public static native void board_figureLayout( GamePtr gamePtr, CurGameInfo gi,
|
public static native void board_figureLayout( GamePtr gamePtr, CurGameInfo gi,
|
||||||
|
|
|
@ -404,10 +404,10 @@ board_drawSnapshot( const BoardCtxt* curBoard, DrawCtx* dctx,
|
||||||
BoardCtxt* newBoard = board_make( MPPARM(curBoard->mpool)
|
BoardCtxt* newBoard = board_make( MPPARM(curBoard->mpool)
|
||||||
curBoard->model,
|
curBoard->model,
|
||||||
curBoard->server, dctx, curBoard->util );
|
curBoard->server, dctx, curBoard->util );
|
||||||
|
board_setDraw( newBoard, dctx ); /* so draw_dictChanged() will get called */
|
||||||
XP_U16 fontWidth = width / curBoard->gi->boardSize;
|
XP_U16 fontWidth = width / curBoard->gi->boardSize;
|
||||||
board_figureLayout( newBoard, curBoard->gi, 0, 0, width, height,
|
board_figureLayout( newBoard, curBoard->gi, 0, 0, width, height,
|
||||||
0, 0, 0, fontWidth, width, XP_TRUE, NULL );
|
0, 0, 0, fontWidth, width, XP_FALSE, NULL );
|
||||||
board_draw( newBoard );
|
board_draw( newBoard );
|
||||||
board_destroy( newBoard );
|
board_destroy( newBoard );
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue