本文整理汇总了C++中Bitmap::FloodFill方法的典型用法代码示例。如果您正苦于以下问题:C++ Bitmap::FloodFill方法的具体用法?C++ Bitmap::FloodFill怎么用?C++ Bitmap::FloodFill使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Bitmap
的用法示例。
在下文中一共展示了Bitmap::FloodFill方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: Draw
void InventoryScreen::Draw(Bitmap *ds)
{
color_t draw_color = ds->GetCompatibleColor(play.sierra_inv_color);
ds->FillRect(Rect(0,0,windowwid,windowhit), draw_color);
draw_color = ds->GetCompatibleColor(0);
ds->FillRect(Rect(barxp,bartop, windowwid - 2,buttonyp-1), draw_color);
for (int i = top_item; i < numitems; ++i) {
if (i >= top_item + num_visible_items)
break;
Bitmap *spof=spriteset[dii[i].sprnum];
wputblock(ds, barxp+1+((i-top_item)%4)*widest+widest/2-spof->GetWidth()/2,
bartop+1+((i-top_item)/4)*highest+highest/2-spof->GetHeight()/2,spof,1);
}
#define BUTTONWID Math::Max(1, game.SpriteInfos[btn_select_sprite].Width)
// Draw select, look and OK buttons
wputblock(ds, 2, buttonyp + 2, spriteset[btn_look_sprite], 1);
wputblock(ds, 3+BUTTONWID, buttonyp + 2, spriteset[btn_select_sprite], 1);
wputblock(ds, 4+BUTTONWID*2, buttonyp + 2, spriteset[btn_ok_sprite], 1);
// Draw Up and Down buttons if required
Bitmap *arrowblock = BitmapHelper::CreateTransparentBitmap (ARROWBUTTONWID, ARROWBUTTONWID);
draw_color = arrowblock->GetCompatibleColor(0);
if (play.sierra_inv_color == 0)
draw_color = ds->GetCompatibleColor(14);
arrowblock->DrawLine(Line(ARROWBUTTONWID/2, 2, ARROWBUTTONWID-2, 9), draw_color);
arrowblock->DrawLine(Line(ARROWBUTTONWID/2, 2, 2, 9), draw_color);
arrowblock->DrawLine(Line(2, 9, ARROWBUTTONWID-2, 9), draw_color);
arrowblock->FloodFill(ARROWBUTTONWID/2, 4, draw_color);
if (top_item > 0)
wputblock(ds, windowwid-ARROWBUTTONWID, buttonyp + 2, arrowblock, 1);
if (top_item + num_visible_items < numitems)
arrowblock->FlipBlt(arrowblock, windowwid-ARROWBUTTONWID, buttonyp + 4 + ARROWBUTTONWID, Common::kBitmap_VFlip);
delete arrowblock;
}
示例2: __actual_invscreen
int __actual_invscreen() {
int BUTTONAREAHEIGHT = get_fixed_pixel_size(30);
int cmode=CURS_ARROW, toret = -1;
int top_item = 0, num_visible_items = 0;
int MAX_ITEMAREA_HEIGHT = ((scrnhit - BUTTONAREAHEIGHT) - get_fixed_pixel_size(20));
in_inv_screen++;
inv_screen_newroom = -1;
Bitmap *ds = NULL;
start_actinv:
ds = SetVirtualScreen(virtual_screen);
DisplayInvItem dii[MAX_INV];
int numitems=0,ww,widest=0,highest=0;
if (charextra[game.playercharacter].invorder_count < 0)
update_invorder();
if (charextra[game.playercharacter].invorder_count == 0) {
DisplayMessage(996);
in_inv_screen--;
return -1;
}
if (inv_screen_newroom >= 0) {
in_inv_screen--;
NewRoom(inv_screen_newroom);
return -1;
}
for (ww = 0; ww < charextra[game.playercharacter].invorder_count; ww++) {
if (game.invinfo[charextra[game.playercharacter].invorder[ww]].name[0]!=0) {
dii[numitems].num = charextra[game.playercharacter].invorder[ww];
dii[numitems].sprnum = game.invinfo[charextra[game.playercharacter].invorder[ww]].pic;
int snn=dii[numitems].sprnum;
if (spritewidth[snn] > widest) widest=spritewidth[snn];
if (spriteheight[snn] > highest) highest=spriteheight[snn];
numitems++;
}
}
if (numitems != charextra[game.playercharacter].invorder_count)
quit("inconsistent inventory calculations");
widest += get_fixed_pixel_size(4);
highest += get_fixed_pixel_size(4);
num_visible_items = (MAX_ITEMAREA_HEIGHT / highest) * ICONSPERLINE;
int windowhit = highest * (numitems/ICONSPERLINE) + get_fixed_pixel_size(4);
if ((numitems%ICONSPERLINE) !=0) windowhit+=highest;
if (windowhit > MAX_ITEMAREA_HEIGHT) {
windowhit = (MAX_ITEMAREA_HEIGHT / highest) * highest + get_fixed_pixel_size(4);
}
windowhit += BUTTONAREAHEIGHT;
int windowwid = widest*ICONSPERLINE + get_fixed_pixel_size(4);
if (windowwid < get_fixed_pixel_size(105)) windowwid = get_fixed_pixel_size(105);
int windowxp=scrnwid/2-windowwid/2;
int windowyp=scrnhit/2-windowhit/2;
int buttonyp=windowyp+windowhit-BUTTONAREAHEIGHT;
color_t draw_color = ds->GetCompatibleColor(play.sierra_inv_color);
ds->FillRect(Rect(windowxp,windowyp,windowxp+windowwid,windowyp+windowhit), draw_color);
draw_color = ds->GetCompatibleColor(0);
int bartop = windowyp + get_fixed_pixel_size(2);
int barxp = windowxp + get_fixed_pixel_size(2);
ds->FillRect(Rect(barxp,bartop, windowxp + windowwid - get_fixed_pixel_size(2),buttonyp-1), draw_color);
for (ww = top_item; ww < numitems; ww++) {
if (ww >= top_item + num_visible_items)
break;
Bitmap *spof=spriteset[dii[ww].sprnum];
wputblock(ds, barxp+1+((ww-top_item)%4)*widest+widest/2-spof->GetWidth()/2,
bartop+1+((ww-top_item)/4)*highest+highest/2-spof->GetHeight()/2,spof,1);
}
if ((spriteset[2041] == NULL) || (spriteset[2042] == NULL) || (spriteset[2043] == NULL))
quit("!InventoryScreen: one or more of the inventory screen graphics have been deleted");
#define BUTTONWID spritewidth[2042]
// Draw select, look and OK buttons
wputblock(ds, windowxp+2, buttonyp + get_fixed_pixel_size(2), spriteset[2041], 1);
wputblock(ds, windowxp+3+BUTTONWID, buttonyp + get_fixed_pixel_size(2), spriteset[2042], 1);
wputblock(ds, windowxp+4+BUTTONWID*2, buttonyp + get_fixed_pixel_size(2), spriteset[2043], 1);
// Draw Up and Down buttons if required
const int ARROWBUTTONWID = 11;
Bitmap *arrowblock = BitmapHelper::CreateTransparentBitmap (ARROWBUTTONWID, ARROWBUTTONWID);
draw_color = arrowblock->GetCompatibleColor(0);
if (play.sierra_inv_color == 0)
draw_color = ds->GetCompatibleColor(14);
arrowblock->DrawLine(Line(ARROWBUTTONWID/2, 2, ARROWBUTTONWID-2, 9), draw_color);
arrowblock->DrawLine(Line(ARROWBUTTONWID/2, 2, 2, 9), draw_color);
arrowblock->DrawLine(Line(2, 9, ARROWBUTTONWID-2, 9), draw_color);
arrowblock->FloodFill(ARROWBUTTONWID/2, 4, draw_color);
if (top_item > 0)
wputblock(ds, windowxp+windowwid-ARROWBUTTONWID, buttonyp + get_fixed_pixel_size(2), arrowblock, 1);
if (top_item + num_visible_items < numitems)
arrowblock->FlipBlt(arrowblock, windowxp+windowwid-ARROWBUTTONWID, buttonyp + get_fixed_pixel_size(4) + ARROWBUTTONWID, Common::kBitmap_VFlip);
delete arrowblock;
domouse(1);
set_mouse_cursor(cmode);
int wasonitem=-1;
//.........这里部分代码省略.........
示例3: is_route_possible
int is_route_possible(int fromx, int fromy, int tox, int toy, Bitmap *wss)
{
wallscreen = wss;
suggestx = -1;
// ensure it's a memory bitmap, so we can use direct access to line[] array
if ((wss == NULL) || (!wss->IsMemoryBitmap()) || (wss->GetColorDepth() != 8))
quit("is_route_possible: invalid walkable areas bitmap supplied");
if (wallscreen->GetPixel(fromx, fromy) < 1)
return 0;
Bitmap *tempw = BitmapHelper::CreateBitmapCopy(wallscreen, 8);
if (tempw == NULL)
quit("no memory for route calculation");
if (!tempw->IsMemoryBitmap())
quit("tempw is not memory bitmap");
int dd, ff;
// initialize array for finding widths of walkable areas
int thisar, inarow = 0, lastarea = 0;
int walk_area_times[MAX_WALK_AREAS + 1];
for (dd = 0; dd <= MAX_WALK_AREAS; dd++) {
walk_area_times[dd] = 0;
walk_area_granularity[dd] = 0;
}
for (ff = 0; ff < tempw->GetHeight(); ff++) {
const uint8_t *tempw_scanline = tempw->GetScanLine(ff);
for (dd = 0; dd < tempw->GetWidth(); dd++) {
thisar = tempw_scanline[dd];
// count how high the area is at this point
if ((thisar == lastarea) && (thisar > 0))
inarow++;
else if (lastarea > MAX_WALK_AREAS)
quit("!Calculate_Route: invalid colours in walkable area mask");
else if (lastarea != 0) {
walk_area_granularity[lastarea] += inarow;
walk_area_times[lastarea]++;
inarow = 0;
}
lastarea = thisar;
}
}
for (dd = 0; dd < tempw->GetWidth(); dd++) {
for (ff = 0; ff < tempw->GetHeight(); ff++) {
uint8_t *tempw_scanline = tempw->GetScanLineForWriting(ff);
thisar = tempw_scanline[dd];
if (thisar > 0)
tempw_scanline[dd] = 1;
// count how high the area is at this point
if ((thisar == lastarea) && (thisar > 0))
inarow++;
else if (lastarea != 0) {
walk_area_granularity[lastarea] += inarow;
walk_area_times[lastarea]++;
inarow = 0;
}
lastarea = thisar;
}
}
// find the average "width" of a path in this walkable area
for (dd = 1; dd <= MAX_WALK_AREAS; dd++) {
if (walk_area_times[dd] == 0) {
walk_area_granularity[dd] = MAX_GRANULARITY;
continue;
}
walk_area_granularity[dd] /= walk_area_times[dd];
if (walk_area_granularity[dd] <= 4)
walk_area_granularity[dd] = 2;
else if (walk_area_granularity[dd] <= 15)
walk_area_granularity[dd] = 3;
else
walk_area_granularity[dd] = MAX_GRANULARITY;
/*char toprnt[200];
sprintf(toprnt,"area %d: Gran %d", dd, walk_area_granularity[dd]);
winalert(toprnt); */
}
walk_area_granularity[0] = MAX_GRANULARITY;
tempw->FloodFill(fromx, fromy, 232);
if (tempw->GetPixel(tox, toy) != 232)
{
// Destination pixel is not walkable
// Try the 100x100 square around the target first at 3-pixel granularity
int tryFirstX = tox - 50, tryToX = tox + 50;
int tryFirstY = toy - 50, tryToY = toy + 50;
if (!find_nearest_walkable_area(tempw, tryFirstX, tryFirstY, tryToX, tryToY, tox, toy, 3))
{
// Nothing found, sweep the whole room at 5 pixel granularity
find_nearest_walkable_area(tempw, 0, 0, tempw->GetWidth(), tempw->GetHeight(), tox, toy, 5);
}
delete tempw;
//.........这里部分代码省略.........