|
Polski Portal COLOBOTa COLOBOT Polish Portal |
|
Programy dla obcych - Nowi, lepsi przeciwnicy.
Berserker - 25-03-2009, 18:25 Temat postu: Nowi, lepsi przeciwnicy. Jak juz kazdy zauwazyl wszyscy miela tego colobota na czesci i skladaja z niego czesc druga. W drugiej czesci raczej przeciwnicy nie powinni byc zaprogramowani "Znajdz i zostan zniszczonym". Wiec moze by jakies programy napisac dla mrowek etc?
Kod: | extern void object::Attack( )
{
int list[], i;
object p,pp;
float dist,dir,r;
point dest,lastPos;
errmode(0); // ne stoppe pas si erreur
while ( ismovie() != 0 ) wait(1);
i = 0;
list[i++] = WingedGrabber;
list[i++] = TrackedGrabber;
list[i++] = WheeledGrabber;
list[i++] = LeggedGrabber;
list[i++] = WingedShooter;
list[i++] = TrackedShooter;
list[i++] = WheeledShooter;
list[i++] = LeggedShooter;
list[i++] = WingedOrgaShooter;
list[i++] = TrackedOrgaShooter;
list[i++] = WheeledOrgaShooter;
list[i++] = LeggedOrgaShooter;
list[i++] = WingedSniffer;
list[i++] = TrackedSniffer;
list[i++] = WheeledSniffer;
list[i++] = LeggedSniffer;
list[i++] = Thumper;
list[i++] = PhazerShooter;
list[i++] = Recycler;
list[i++] = Shielder;
list[i++] = Me;
list[i++] = Derrick;
list[i++] = BotFactory;
list[i++] = PowerStation;
list[i++] = Converter;
list[i++] = RepairCenter;
list[i++] = DefenseTower;
list[i++] = ResearchCenter;
list[i++] = RadarStation;
list[i++] = ExchangePost;
list[i++] = PowerPlant;
list[i++] = AutoLab;
list[i++] = NuclearPlant;
list[i++] = Titanium;
list[i++] = NuclearCell;
while ( true )
{
if ( load == null ) // ne porte rien ?
{
p = radar(OrgaMatter); // cherche matičre
if ( p == null )
{
float p;// puissance max des moteurs
float r;// nombre aléatoire
point c;// centre de la zone permise
c.x = 0;
c.y = 0;
c.z = 0;
p = 1;
jet( rand()*4 + 1);
{
if (distance(position, c) > 275)
{
if (direction(c) > 0) motor(0.7*p, p); else motor(p, 0.7*p);
while (abs(direction(c)) > 30) wait(1);
}
motor(p,p);
r = rand();
if (r < 0.4)
{
motor(p, p-rand()*0.8);
}
if (r > 0.6)
{
motor(p-rand()*0.8, p);
}
if (r <= 0.7 and r >= 0.3) jet(rand()*4 + 1);
wait(1);
}
}
else
{
dest = p.position;
dest.z = position.z;
dist = distance(dest, position);
if ( dist > 1.25 )
{
jet(1); // monte
goto(p.position); // va sur la matičre
}
else
{
jet(-1); // descend
while ( altitude > 0 );
grab(); // prend la matičre
jet(1);
}
}
}
else // porte matičre ?
{
jet(1); // monte
p = radar(list, 0, 360, 0, 6000, 1, FilterOnlyLanding);
if ( p == null )
{
jet(1); // monte
dest = position;
dest.x += (rand()-0.5)*10;
dest.y += (rand()-0.5)*10;
goto(dest); // va n'importe oů
wait(2);
}
else
{
dest = p.position;
dest.z = position.z;
dist = distance(dest, position);
if ( dist > 1.25 )
{
dir = direction(p.position);
motor(1-dir/90, 1+dir/90);
}
else
{
drop(); // lâche la mat
wait(2);
}
}
}
}
}
|
Program dla osy ktora juz nie bedzie jak glupia modlic sie nad celem tylko zrzuci materie i poleci dalej.
colobotwymiiata - 25-03-2009, 18:32
Hmm.. myślę, że troche nie w tym dziale. Zrób temat w dziale "Colobot 2" i tam ewentualnie wrzucaj takie programy.
Berserker - 25-03-2009, 19:20
Ciezko mi bylo zdecydowac, z jednej strony tematem glownym jest colobot 2, ale z drugiej te programy w koncu do wykorzystania sa w pierwszej czesci i istnieje opcja, ze beda tylko w pierwszej czesci. Ostatecznie zalozylem go tutaj, jak cos to ktos go przeniesie.
Abadon - 27-03-2009, 21:31
Dobra z tym programem to niech tutaj już będzie. Gdy będą jakieś konkrety odnośnie Colobota 2 to zapewnię wybierze się programy z tego działu do jakiegoś pakietu podstawowych programów do Colobota 2, oczywiście pytając się wcześniej o zgodę autora, ale póki co nie wyprzedzajmy przyszłości.
No właśnie wszyscy tylko programy dla robotów robią a o mrówkach i spółce zapomniało się. Sam też muszę wkrótce coś wymyślić.
Berserker - 27-03-2009, 23:12
Daje funkcje tutaj i w temacie z funkcjami, gdyz napisalem ja z mysla o obcych.
Funkcja oblicza najmniejsza mozliwa odleglosc miedzy dwoma rodzajami obiektow.
Kod: | bool object::Dist(object obj1, object obj2, float len)
{
int i1, i2;
float dist;
object alien, bot;
i1 = 1;
i2 = 1;
dist = 1000;
while(i2 < 1000 and i1 < 1000)
{
if(i1 == i2)
{
i2++;
}
alien = retobject(i1++);
if(alien == null)
{
continue;
}
bot = retobject(i2++);
if(bot == null)
{
i1--;
continue;
}
if(alien.category != obj1.category)
{
i2--;
continue;
}
if(bot.category != obj2.category)
{
i1--;
continue;
}
if(distance2d(bot.position, alien.position) < dist)
{
dist = distance2d(bot.position, alien.position);
}
}
if(dist > len)
{
return false;
}
else
{
return true;
}
} |
Uwazam, ze moze to sie przydac do pewnego zorganizowania obcych, ktorzy beda atakowac jak na komende "OGNIA!" ;]
Lub tez wprowadzic element ochrony czegos przez owady (np materii organicznej) - dopoki sie nie zblizymy sa spokojne.
adiblol - 28-03-2009, 10:40
A tego zarejestrowani później nie znają, a część pewnie zapomniała
http://www.colobot.yoyo.p...php?p=1262#1262
|
|