mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-20 22:26:54 +01:00
Merge remote-tracking branch 'origin/android_branch' into android_thumbnail
This commit is contained in:
commit
6776490c40
7 changed files with 112 additions and 20 deletions
|
@ -1456,6 +1456,60 @@ board_invalRect( BoardCtxt* board, XP_Rect* rect )
|
||||||
}
|
}
|
||||||
} /* board_invalRect */
|
} /* board_invalRect */
|
||||||
|
|
||||||
|
#ifdef XWFEATURE_ACTIVERECT
|
||||||
|
XP_Bool
|
||||||
|
board_getActiveRect( const BoardCtxt* board, XP_Rect* rect )
|
||||||
|
{
|
||||||
|
XP_Bool found = XP_FALSE;
|
||||||
|
XP_USE( rect );
|
||||||
|
XP_U16 minCol = 1000;
|
||||||
|
XP_U16 maxCol = 0;
|
||||||
|
XP_U16 minRow = 1000;
|
||||||
|
XP_U16 maxRow = 0;
|
||||||
|
const ModelCtxt* model = board->model;
|
||||||
|
XP_U16 nCols = model_numCols( board->model );
|
||||||
|
XP_S16 turn = board->selPlayer;
|
||||||
|
XP_U16 col, row;
|
||||||
|
|
||||||
|
for ( col = 0; col < nCols; ++col ) {
|
||||||
|
for ( row = 0; row < nCols; ++row ) {
|
||||||
|
if ( model_getTile( model, col, row, XP_TRUE, turn, NULL, NULL,
|
||||||
|
NULL, NULL ) ) {
|
||||||
|
found = XP_TRUE;
|
||||||
|
if ( row < minRow ) {
|
||||||
|
minRow = row;
|
||||||
|
}
|
||||||
|
if ( row > maxRow ) {
|
||||||
|
maxRow = row;
|
||||||
|
}
|
||||||
|
if ( col < minCol ) {
|
||||||
|
minCol = col;
|
||||||
|
}
|
||||||
|
if ( col > maxCol ) {
|
||||||
|
maxCol = col;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( !found ) {
|
||||||
|
minCol = maxCol = nCols / 2;
|
||||||
|
minRow = maxRow = nCols / 2;
|
||||||
|
found = XP_TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
XP_Rect upperLeft, lowerRight;
|
||||||
|
getCellRect( board, minCol, minRow, &upperLeft );
|
||||||
|
getCellRect( board, maxCol, maxRow, &lowerRight );
|
||||||
|
rect->left = upperLeft.left;
|
||||||
|
rect->top = upperLeft.top;
|
||||||
|
rect->width = (lowerRight.left + lowerRight.width) - upperLeft.left;
|
||||||
|
rect->height = (lowerRight.top + lowerRight.height) - upperLeft.top;
|
||||||
|
|
||||||
|
return found;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/* When the tray's hidden, check if it overlaps where the board wants to be,
|
/* When the tray's hidden, check if it overlaps where the board wants to be,
|
||||||
* and adjust the board's rect if needed so that hit-testing will work
|
* and adjust the board's rect if needed so that hit-testing will work
|
||||||
* "through" where the tray used to be.
|
* "through" where the tray used to be.
|
||||||
|
|
|
@ -96,6 +96,9 @@ void board_setTimerLoc( BoardCtxt* board,
|
||||||
XP_U16 timerWidth, XP_U16 timerHeight );
|
XP_U16 timerWidth, XP_U16 timerHeight );
|
||||||
void board_invalAll( BoardCtxt* board );
|
void board_invalAll( BoardCtxt* board );
|
||||||
void board_invalRect( BoardCtxt* board, XP_Rect* rect );
|
void board_invalRect( BoardCtxt* board, XP_Rect* rect );
|
||||||
|
#ifdef XWFEATURE_ACTIVERECT
|
||||||
|
XP_Bool board_getActiveRect( const BoardCtxt* board, XP_Rect* rect );
|
||||||
|
#endif
|
||||||
|
|
||||||
XP_Bool board_draw( BoardCtxt* board );
|
XP_Bool board_draw( BoardCtxt* board );
|
||||||
|
|
||||||
|
@ -119,6 +122,7 @@ BoardObjectType board_getFocusOwner( BoardCtxt* board );
|
||||||
|
|
||||||
void board_hiliteCellAt( BoardCtxt* board, XP_U16 col, XP_U16 row );
|
void board_hiliteCellAt( BoardCtxt* board, XP_U16 col, XP_U16 row );
|
||||||
|
|
||||||
|
|
||||||
void board_resetEngine( BoardCtxt* board );
|
void board_resetEngine( BoardCtxt* board );
|
||||||
|
|
||||||
XP_Bool board_commitTurn( BoardCtxt* board );
|
XP_Bool board_commitTurn( BoardCtxt* board );
|
||||||
|
|
|
@ -596,6 +596,7 @@ model_getTile( const ModelCtxt* model, XP_U16 col, XP_U16 row,
|
||||||
{
|
{
|
||||||
CellTile cellTile = getModelTileRaw( model, col, row );
|
CellTile cellTile = getModelTileRaw( model, col, row );
|
||||||
XP_Bool pending = XP_FALSE;
|
XP_Bool pending = XP_FALSE;
|
||||||
|
XP_Bool inUse = XP_TRUE;
|
||||||
|
|
||||||
if ( (cellTile & TILE_PENDING_BIT) != 0 ) {
|
if ( (cellTile & TILE_PENDING_BIT) != 0 ) {
|
||||||
if ( getPending
|
if ( getPending
|
||||||
|
@ -609,24 +610,22 @@ model_getTile( const ModelCtxt* model, XP_U16 col, XP_U16 row,
|
||||||
}
|
}
|
||||||
|
|
||||||
/* this needs to happen after the above b/c cellTile gets changed */
|
/* this needs to happen after the above b/c cellTile gets changed */
|
||||||
if ( (cellTile & TILE_EMPTY_BIT) != 0 ) {
|
inUse = 0 == (cellTile & TILE_EMPTY_BIT);
|
||||||
return XP_FALSE;
|
if ( inUse ) {
|
||||||
|
if ( NULL != tileP ) {
|
||||||
|
*tileP = cellTile & TILE_VALUE_MASK;
|
||||||
|
}
|
||||||
|
if ( NULL != isBlank ) {
|
||||||
|
*isBlank = IS_BLANK(cellTile);
|
||||||
|
}
|
||||||
|
if ( NULL != pendingP ) {
|
||||||
|
*pendingP = pending;
|
||||||
|
}
|
||||||
|
if ( !!recentP ) {
|
||||||
|
*recentP = (cellTile & PREV_MOVE_BIT) != 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
return inUse;
|
||||||
if ( NULL != tileP ) {
|
|
||||||
*tileP = cellTile & TILE_VALUE_MASK;
|
|
||||||
}
|
|
||||||
if ( NULL != isBlank ) {
|
|
||||||
*isBlank = IS_BLANK(cellTile);
|
|
||||||
}
|
|
||||||
if ( NULL != pendingP ) {
|
|
||||||
*pendingP = pending;
|
|
||||||
}
|
|
||||||
if ( !!recentP ) {
|
|
||||||
*recentP = (cellTile & PREV_MOVE_BIT) != 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return XP_TRUE;
|
|
||||||
} /* model_getTile */
|
} /* model_getTile */
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
|
@ -113,6 +113,7 @@ DEFINES += -DXWFEATURE_HILITECELL
|
||||||
DEFINES += -DXWFEATURE_CHANGEDICT
|
DEFINES += -DXWFEATURE_CHANGEDICT
|
||||||
DEFINES += -DXWFEATURE_DEVID
|
DEFINES += -DXWFEATURE_DEVID
|
||||||
DEFINES += -DXWFEATURE_COMMSACK
|
DEFINES += -DXWFEATURE_COMMSACK
|
||||||
|
#DEFINES += -DXWFEATURE_ACTIVERECT
|
||||||
DEFINES += -DCOMMS_XPORT_FLAGSPROC
|
DEFINES += -DCOMMS_XPORT_FLAGSPROC
|
||||||
DEFINES += -DINITIAL_CLIENT_VERS=2
|
DEFINES += -DINITIAL_CLIENT_VERS=2
|
||||||
|
|
||||||
|
|
|
@ -1071,6 +1071,28 @@ handle_memstats( GtkWidget* XP_UNUSED(widget), GtkGameGlobals* globals )
|
||||||
} /* handle_memstats */
|
} /* handle_memstats */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef XWFEATURE_ACTIVERECT
|
||||||
|
static gint
|
||||||
|
inval_board_ontimer( gpointer data )
|
||||||
|
{
|
||||||
|
GtkGameGlobals* globals = (GtkGameGlobals*)data;
|
||||||
|
BoardCtxt* board = globals->cGlobals.game.board;
|
||||||
|
board_draw( board );
|
||||||
|
return XP_FALSE;
|
||||||
|
} /* pen_timer_func */
|
||||||
|
|
||||||
|
static void
|
||||||
|
frame_active( GtkWidget* XP_UNUSED(widget), GtkGameGlobals* globals )
|
||||||
|
{
|
||||||
|
XP_Rect rect;
|
||||||
|
BoardCtxt* board = globals->cGlobals.game.board;
|
||||||
|
board_getActiveRect( board, &rect );
|
||||||
|
frame_active_rect( globals->draw, &rect );
|
||||||
|
board_invalRect( board, &rect );
|
||||||
|
(void)g_timeout_add( 1000, inval_board_ontimer, globals );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
static GtkWidget*
|
static GtkWidget*
|
||||||
createAddItem( GtkWidget* parent, gchar* label,
|
createAddItem( GtkWidget* parent, gchar* label,
|
||||||
GtkSignalFunc handlerFunc, GtkGameGlobals* globals )
|
GtkSignalFunc handlerFunc, GtkGameGlobals* globals )
|
||||||
|
@ -1157,6 +1179,11 @@ makeMenus( GtkGameGlobals* globals )
|
||||||
GTK_SIGNAL_FUNC(handle_memstats), globals );
|
GTK_SIGNAL_FUNC(handle_memstats), globals );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef XWFEATURE_ACTIVERECT
|
||||||
|
fileMenu = makeAddSubmenu( menubar, "Test" );
|
||||||
|
(void)createAddItem( fileMenu, "Frame active area",
|
||||||
|
GTK_SIGNAL_FUNC(frame_active), globals );
|
||||||
|
#endif
|
||||||
/* (void)createAddItem( fileMenu, "Print board", */
|
/* (void)createAddItem( fileMenu, "Print board", */
|
||||||
/* GTK_SIGNAL_FUNC(handle_print_board), globals ); */
|
/* GTK_SIGNAL_FUNC(handle_print_board), globals ); */
|
||||||
|
|
||||||
|
|
|
@ -1299,9 +1299,9 @@ allocAndSet( GdkColormap* map, GdkColor* color, unsigned short red,
|
||||||
gboolean success =
|
gboolean success =
|
||||||
#endif
|
#endif
|
||||||
gdk_colormap_alloc_color( map,
|
gdk_colormap_alloc_color( map,
|
||||||
color,
|
color,
|
||||||
TRUE, /* writeable */
|
TRUE, /* writeable */
|
||||||
TRUE ); /* best-match */
|
TRUE ); /* best-match */
|
||||||
XP_ASSERT( success );
|
XP_ASSERT( success );
|
||||||
} /* allocAndSet */
|
} /* allocAndSet */
|
||||||
|
|
||||||
|
@ -1440,5 +1440,11 @@ draw_gtk_status( GtkDrawCtx* dctx, char ch )
|
||||||
&dctx->black, NULL );
|
&dctx->black, NULL );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
frame_active_rect( GtkDrawCtx* dctx, const XP_Rect* rect )
|
||||||
|
{
|
||||||
|
gtkFillRect( dctx, rect, &dctx->grey );
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* PLATFORM_GTK */
|
#endif /* PLATFORM_GTK */
|
||||||
|
|
||||||
|
|
|
@ -25,5 +25,6 @@
|
||||||
DrawCtx* gtkDrawCtxtMake( GtkWidget *widget, GtkGameGlobals* globals );
|
DrawCtx* gtkDrawCtxtMake( GtkWidget *widget, GtkGameGlobals* globals );
|
||||||
|
|
||||||
void draw_gtk_status( GtkDrawCtx* draw, char ch );
|
void draw_gtk_status( GtkDrawCtx* draw, char ch );
|
||||||
|
void frame_active_rect( GtkDrawCtx* dctx, const XP_Rect* rect );
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue