123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534 |
- #include <OMATRIX.h>
- #include <OWORLD.h>
- #include <OWORLDMT.h>
- #include <OWEATHER.h>
- #include <OPLANT.h>
- #include <OTERRAIN.h>
- #include <ALL.h>
- #include <math.h>
- static short opt_temp[3] = { 32, 25, 28 };
- #define PLANT_ARRAY_SIZE 8
- inline int rand_inner_x()
- {
-
-
- return ZOOM_LOC_WIDTH / 4 + m.random(ZOOM_LOC_WIDTH/2);
- }
- inline int rand_inner_y()
- {
- return (ZOOM_LOC_HEIGHT * 3) / 8 + m.random(ZOOM_LOC_HEIGHT/4);
- }
- void World::plant_ops()
- {
- plant_grow(40);
- plant_reprod(10);
- plant_death();
- plant_spread(50);
- }
- void World::plant_grow(int pGrow, int scanDensity)
- {
-
- int yBase = m.random(scanDensity);
- int xBase = m.random(scanDensity);
- for( int y = yBase; y < max_y_loc; y += scanDensity)
- for( int x = xBase; x < max_x_loc; x += scanDensity)
- {
- Location *l = get_loc(x,y);
- short bitmapId, basePlantId;
-
- if( l->is_plant() && m.random(100) < pGrow &&
- (basePlantId = plant_res.plant_recno(bitmapId = l->plant_id())) != 0 &&
- bitmapId - plant_res[basePlantId]->first_bitmap < plant_res[basePlantId]->bitmap_count -1)
- {
-
- l->grow_plant();
- }
- }
- }
- void World::plant_reprod(int pReprod, int scanDensity)
- {
- if( plant_count > plant_limit )
- return;
- if( 5 * plant_count < 4 * plant_limit )
- pReprod++;
-
- short t = weather.temp_c();
-
- int yBase = m.random(scanDensity);
- int xBase = m.random(scanDensity);
- for( int y = yBase; y < max_y_loc; y += scanDensity)
- {
- for( int x = xBase; x < max_x_loc; x += scanDensity)
- {
- Location *l = get_loc(x,y);
- short bitmapId, basePlantId, plantGrade;
-
- if( l->is_plant() && (basePlantId = plant_res.plant_recno(
- bitmapId = l->plant_id())) != 0 &&
- ((plantGrade = bitmapId - plant_res[basePlantId]->first_bitmap) >= 3 ||
- plantGrade == plant_res[basePlantId]->bitmap_count-1))
- {
-
- short oTemp = opt_temp[plant_res[basePlantId]->climate_zone -1];
- short tempEffect = 5 - abs( oTemp - t);
- tempEffect = tempEffect > 0 ? tempEffect : 0;
- if( m.random(100) < tempEffect * pReprod)
- {
-
- char trial = 2;
- Location *newl;
- while( trial --)
- {
- newl = NULL;
- switch(m.random(8))
- {
- case 0:
- if( y > 0)
- newl = get_loc(x,y-1);
- break;
- case 1:
- if( x < max_x_loc-1 )
- newl = get_loc(x+1,y);
- break;
- case 2:
- if( y < max_y_loc-1 )
- newl = get_loc(x,y+1);
- break;
- case 3:
- if( x > 0)
- newl = get_loc(x-1,y);
- break;
- case 4:
- if( y > 0 && x > 0)
- newl = get_loc(x-1,y-1);
- break;
- case 5:
- if( y > 0 && x < max_x_loc-1 )
- newl = get_loc(x+1,y-1);
- break;
- case 6:
- if( y < max_y_loc-1 && x < max_x_loc-1)
- newl = get_loc(x+1,y+1);
- break;
- case 7:
- if( y < max_y_loc-1 && x > 0)
- newl = get_loc(x-1,y+1);
- break;
- }
- char teraType;
-
- if( newl && newl->can_add_plant() &&
- (plant_res[basePlantId]->tera_type[0] ==
- (teraType = terrain_res[newl->terrain_id]->average_type) ||
- plant_res[basePlantId]->tera_type[1] == teraType ||
- plant_res[basePlantId]->tera_type[2] == teraType) )
-
- {
- newl->set_plant(plant_res[basePlantId]->first_bitmap
- , rand_inner_x(), rand_inner_y() );
-
- newl->set_fire_src(100);
- plant_count++;
-
-
-
-
-
- break;
- }
- }
- }
- }
- }
- }
- }
- void World::plant_spread(int pSpread)
- {
- if( plant_count > plant_limit)
- return;
- if( 5 * plant_count < 4 * plant_limit )
- pSpread += pSpread;
- if(m.random(1000) >= pSpread )
- return;
-
- short t = weather.temp_c();
-
- int y = 1+m.random(max_y_loc-2);
- int x = 1+m.random(max_x_loc-2);
- Location *l = get_loc(x,y);
- int build_flag = TRUE;
- char teraType = terrain_res[l->terrain_id]->average_type;
-
- for( int y1 = y-1; y1 <= y+1; ++y1)
- for( int x1 = x-1; x1 <= x+1; ++x1)
- {
- l = get_loc(x1,y1);
-
- if( !l->can_add_plant() || terrain_res[l->terrain_id]->average_type != teraType)
- build_flag = FALSE;
-
- }
- if( build_flag)
- {
- char climateZone = 0;
- short plantBitmap = 0;
- for( int retry=0; !climateZone && retry < 5; ++retry)
- {
- for( char j=0; j < 3; ++j)
- {
- if( m.random(5) > abs(t- opt_temp[j]) )
- {
- climateZone = j+1;
- plantBitmap = plant_res.scan( climateZone, teraType, 0);
- if( plantBitmap)
- {
- l = get_loc(x,y);
- l->set_plant( plantBitmap, rand_inner_x(), rand_inner_y() );
- l->set_fire_src(100);
- plant_count++;
-
-
-
-
-
- }
- break;
- }
- }
- }
- }
- }
- void World::plant_death(int scanDensity)
- {
- int yBase = m.random(scanDensity);
- int xBase = m.random(scanDensity);
- for( int y = yBase; y < max_y_loc; y += scanDensity)
- {
- for( int x = xBase; x < max_x_loc; x += scanDensity)
- {
- Location *locPtr = get_loc(x,y);
- if( locPtr->is_plant() )
- {
- char neighbour =0;
- char totalSpace =0;
-
- if( x > 0)
- {
- totalSpace++;
- if( (locPtr-1)->is_plant() )
- neighbour++;
- }
-
- if( x < max_x_loc-1)
- {
- totalSpace++;
- if( (locPtr+1)->is_plant() )
- neighbour++;
- }
- if( y > 0)
- {
- locPtr = get_loc(x,y-1);
-
- totalSpace++;
- if( locPtr->is_plant() )
- neighbour++;
-
-
- if( x > 0)
- {
- totalSpace++;
- if( (locPtr-1)->is_plant() )
- neighbour++;
- }
-
- if( x < max_x_loc-1)
- {
- totalSpace++;
- if( (locPtr+1)->is_plant() )
- neighbour++;
- }
- }
- if( y < max_x_loc-1)
- {
- locPtr = get_loc(x,y+1);
-
- totalSpace++;
- if( locPtr->is_plant() )
- neighbour++;
-
-
- if( x > 0)
- {
- totalSpace++;
- if( (locPtr-1)->is_plant() )
- neighbour++;
- }
-
- if( x < max_x_loc-1)
- {
- totalSpace++;
- if( (locPtr+1)->is_plant() )
- neighbour++;
- }
- }
-
- if( m.random(totalSpace) + 2*totalSpace/3 <= neighbour )
- {
- locPtr = get_loc(x,y);
- get_loc(x,y)->remove_plant();
- if( locPtr->fire_src() > 50)
- locPtr->set_fire_src(50);
- plant_count--;
-
-
-
-
-
- }
- }
- }
- }
- }
- void World::plant_init()
- {
- plant_count = 0;
- int trial;
- for(trial = 50; trial > 0; --trial)
- {
-
- int y = 1+m.random(max_y_loc-2);
- int x = 1+m.random(max_x_loc-2);
- Location *l = get_loc(x,y);
- int build_flag = TRUE;
- char teraType = terrain_res[l->terrain_id]->average_type;
-
- for( int y1 = y-1; y1 <= y+1; ++y1)
- for( int x1 = x-1; x1 <= x+1; ++x1)
- {
- l = get_loc(x1,y1);
-
- if( !l->can_add_plant() || terrain_res[l->terrain_id]->average_type != teraType)
- build_flag = FALSE;
-
- }
- if( build_flag )
- {
- short plantBitmap = plant_res.scan( 0, teraType, 0);
- short plantArray[PLANT_ARRAY_SIZE];
- for( int i = 0; i < PLANT_ARRAY_SIZE; ++i)
- {
- plantArray[i] = plant_res.plant_recno(plant_res.scan(0, teraType, 0));
- }
- if( plantArray[0] )
- {
- plant_spray(plantArray, 6+m.random(4), x, y);
- }
- }
- }
- plant_limit = plant_count * 3 / 2;
-
- for(trial = 8; trial > 0; --trial)
- {
- plant_death(2);
- }
- }
- void World::plant_spray(short *plantArray, char strength, short x, short y)
- {
- if( strength <= 0)
- return;
-
- Location *newl = get_loc(x, y);
- short basePlantId = plantArray[m.random(PLANT_ARRAY_SIZE)];
- short plantSize = m.random(plant_res[basePlantId]->bitmap_count);
- if( plantSize > strength)
- plantSize = strength;
- char teraType;
- if( newl && newl->can_add_plant() &&
- (plant_res[basePlantId]->tera_type[0] ==
- (teraType = terrain_res[newl->terrain_id]->average_type) ||
- plant_res[basePlantId]->tera_type[1] == teraType ||
- plant_res[basePlantId]->tera_type[2] == teraType) )
- {
- newl->set_plant(plant_res[basePlantId]->first_bitmap +plantSize
- , rand_inner_x(), rand_inner_y() );
- newl->set_fire_src(100);
- plant_count++;
-
-
-
-
-
- }
- else if( newl && newl->is_plant() &&
-
-
-
-
-
-
-
- (newl->plant_id() - plant_res[plant_res.plant_recno(newl->plant_id())]->first_bitmap) >
- plantSize )
- {
-
- newl->remove_plant();
- newl->set_plant(plant_res[basePlantId]->first_bitmap +plantSize
- , rand_inner_x(), rand_inner_y() );
- newl->set_fire_src(100);
-
-
-
-
-
- }
- else
- {
- plantSize = -1;
- }
- if( plantSize >= 0 && strength)
- {
- char trial = 3;
- while( trial--)
- {
- switch(m.random(8))
- {
- case 0:
- if( y > 0)
- plant_spray(plantArray, strength-1, x,y-1);
- break;
- case 1:
- if( x < max_x_loc-1 )
- plant_spray(plantArray, strength-1, x+1,y);
- break;
- case 2:
- if( y < max_y_loc-1 )
- plant_spray(plantArray, strength-1, x,y+1);
- break;
- case 3:
- if( x > 0)
- plant_spray(plantArray, strength-1, x-1,y);
- break;
- case 4:
- if( y > 0 && x > 0)
- plant_spray(plantArray, strength-1, x-1,y-1);
- break;
- case 5:
- if( y > 0 && x < max_x_loc-1 )
- plant_spray(plantArray, strength-1, x+1,y-1);
- break;
- case 6:
- if( y < max_y_loc-1 && x < max_x_loc-1)
- plant_spray(plantArray, strength-1, x+1,y+1);
- break;
- case 7:
- if( y < max_y_loc-1 && x > 0)
- plant_spray(plantArray, strength-1, x-1,y+1);
- break;
- }
- }
- }
- }
|