introduction
« Linux n'est pas fait pour les jeux ! » - une phrase dépassée : il existe désormais de nombreux jeux merveilleux spécifiquement pour ce merveilleux système. Mais quand même, parfois tu veux quelque chose de spécial qui te conviendrait... Et j'ai décidé de créer ce truc spécial.
Основа
Je ne montrerai pas et ne raconterai pas tout le code (ce n'est pas très intéressant) - juste les points principaux.
1.Caractère
Tous les paramètres du personnage sont répertoriés ici (santé, armure, expérience, etc.). Le dessin et la direction du mouvement sont intéressants (qui ne sont pas disponibles actuellement).
int x = 5, y = 5;
hp = 100,
maxhp = 100,
dm = 20,
armor = 0,
xp = 0,
level = 0,
diff = 10, // сложность
pos = 0; // направление
bool reg = 0,
Mdm = 0, // бонусы
ght = 0;
string color; // цвет будет использован в качестве индикатора состаяния героя
void hero() // здесь происходит перемещение героя на координаты (x ; y)
{
cout << "e[u " << "e[0;0H"; // восстановление позиции курсора, затирание пробелом
for (int i = 0; i <= x; i++)
cout << RIGHT; // макрос "e[1C"
for (int i = 0; i <= y; i++)
cout << DOWN; // макрос "e[1B"
cout << "e[s" << color << "╬"; // сохранение позиции курсора
}
2.Gestion
Comment déplacer le personnage est déjà clair (x—++, y—++). Mais le traitement du clavier est plus intéressant :
char key;
char getkey()
{
system("stty raw");
key = getchar();
system("stty cooked");
return key;
}
Il ne reste plus qu'à définir les « caractères de contrôle ». Vous pouvez le faire en utilisant Switch, mais je déteste ça.
switch(...) case .. : ... ; break
mieux comme ça
#define KEY if (key ==
#define I ){
#define J ;}else
void keys()
{
getkey();
KEY 'a' I x-- ; pos = 1 J
KEY......
}
Beauté! Bouclez les fonctions et parcourez l'écran ! Mais d'une manière ou d'une autre, c'est un peu dur... Et le curseur clignote, et les lettres... Nous allons arranger ça !
//До цикла
cout << "e[?25l"; //отключаем отображение курсора
system("stty -echo"); //отключаем эхо-ввод
system("xset r rate 120 10"); // изменяем задержку на более плавную
//После цикла
//-------Return_normal_system_settings--------
cout << "e[00m";
system("reset");
system("xset r rate 200 20");
Ouah! Un pour cent est prêt !
3.Le monde qui nous entoure
Ici, nous créons des tableaux pour x, y morceaux du monde et les morceaux eux-mêmes (char o[N])
, idem pour les monstres et les bonus.
Créer une fonction world(int objx[N] .... objy[N] ... obj[N], ... objcolor[N])
par analogie avec hero()
, mais avec des paramètres et une boucle supplémentaire pour sortir le tableau... pour s'amuser, on dessine uniquement dans le champ de vision (vis) (if (ox[k] < vis && oy[k]....))
Maintenant, nous remplissons l'écran avec des particules du monde en utilisant des pièces et des passages simples et creux de manière procédurale, en même temps nous entrons dans les ennemis et les objets, pour un hasard complet, nous n'oublions pas srand(time(NULL));
//------------------GENERATION---------------
void rooms()
{
for (int i = 0; i <= 50; i++)
{
px[i] = rand() % 115 + 2;
py[i] = rand() % 34 + 2;
pl[i] = rand() % 5 + 5;
ph[i] = rand() % 5 + 5;
if (px[i] + pl[i] > 117) px[i] = 50 - pl[i] / 2; else
if (px[i] < 2) px[i] = 50 - pl[i] / 2; else
if (py[i] < 1) py[i] = 15 - ph[i] / 2; else
if (py[i] + ph[i] > 37) py[i] = 15 - ph[i] / 2;
for (int j = 0; j <= i; j++)
{
while (px[i] > px[j] && px[i] < px[j] + pl[j])
(px[i]+pl[i]/2 >= 55) ? px[i]++ : px[i]-- ;
while (py[i] > py[j] && py[i] < py[j] + ph[j])
(py[i]+ph[i]/2 >= 18) ? py[i]++ : py[i]-- ;
while (px[i]+pl[i] > px[j] && px[i]+pl[i] < px[j] + pl[j])
(px[i]+pl[i]/2 >= 55) ? px[i]++ : px[i]-- ;
while (py[i]+ph[i] > py[j] && py[i]+ph[i] < py[j] + ph[j])
(py[i]+ph[i]/2 >= 18) ? py[i]++ : py[i]-- ;
}
for (int j = 0; j <= i; j++)
{
while (px[j] + pl[j] >= 116) px[j]-- ;
while (px[j] < 2) px[j]++ ;
while (py[j] < 1) py[j]++ ;
while (py[j] + ph[j] >= 37) py[j]-- ;
}
tx[i] = px[i]+10; ty[i] = py[i]-3;
if (i <= diff)
{
ex[i] = px[i];
ey[i] = py[i];
while (ex[i] < 10){ ex[i]++ ; epos[i] = 3 ;}
while (ey[i] < 10){ ey[i]++ ; epos[i] = 1 ;}
e[i] = evar[pl[i]];
ecolor[i] = "e[00me[31m";
edm[i] = edmvar[pl[i]];
ehp[i] = ehpvar[pl[i]];
exp[i] = expvar[pl[i]];
}
rect(px[i], py[i], pl[i], ph[i]);
}
}
void corrs()
{
int pc, px, py;
for (int i = 0; i <= 4; i++)
{
if (i < 2){
px = 3;
py = rand() % 33 + 3;
pc = 110;
line(px, py, pc, true);
line(px, py+1, pc, true);
} else {
px = rand() % 100 + 3;
py = 3;
pc = 33;
line(px, py, pc, false);
line(px+1, py, pc, false);
}
}
}
4.Interactions
Maintenant, nous devons d'une manière ou d'une autre éviter de traverser les murs et les monstres et recevoir des bonus d'objets.
Nos favoris sont pour et #define
#define TOUCH if (x == ox[i] && y == oy[i] && pos ==
#define HIT x == ex[i] && y == ey[i] && pos ==
for (int i = 0; i <= n; i++)
{
if (i <= diff)
{
if (Mdm) ehp[i]-=2 ; // если бонус "массовый урон" включен
epos[i] = 0;
if (ex[i] < x+5 && ex[i] > x-5 &&
ey[i] < y+5 && ey[i] > y-5 )
{
edel(i); // функция переписывающая предыдущее положение противника
if (ex[i] < x I ex[i]++ ; epos[i] = 1 J
if (ex[i] > x I ex[i]-- ; epos[i] = 2 J
if (ey[i] < y I ey[i]++ ; epos[i] = 3 J
if (ey[i] > y I ey[i]-- ; epos[i] = 4 ;}
}
for (int j = 0; j <= n; j++) // столкновение моба со стенками
while (ex[i] == ox[j] && ey[i] == oy[j] || ex[i] == ex[j] && ey[i] == ey[j] && j != i)
{
if (epos[i] == 1) ex[i]-- ; else
if (epos[i] == 2) ex[i]++ ; else
if (epos[i] == 3) ey[i]-- ; else
if (epos[i] == 4) ey[i]++ ;
}
if (x == ex[i] && y == ey[i]) // "битва"
{
if (ehp[i] > 1)
{
ehp[i] -= dm;
(edm[i] < armor) ?
hp -= 0 :
hp -= edm[i]-armor;
} else {
ex[i] = ey[i] = -1;
xp += exp[i];
ehp[i] = 12;
}
}
if (!ght) // если не призрак проверять столкновение игрока с врагами
{
if (HIT 1) y++ ;else
if (HIT 2) x-- ;else
if (HIT 3) y-- ;else
if (HIT 4) x++ ;
}
}
if (!ght) // то же, но со стенами
{
TOUCH 1 I y++ J
TOUCH 2 I x-- J
TOUCH 3 I y-- J
TOUCH 4 ) x++ ;
}
}
5.Menu
Nous affichons simplement le menu, numérotons les éléments et utilisons getkey() pour traiter le choix du joueur. Nous écrivons la barre d'état du personnage, implémentons le menu de mise à niveau, écrivons la trame de fond et nous obtenons ce que j'ai appelé « Sous-sol ».
Conclusion
C'est quelque chose comme ça. Tu peux y jouer
$ sudo chmod +x Subsoil-1.0/Subsoil
$ Subsoil-1.0/Subsoil
, ou, enfin inspiré, écrivez-vous une aventure à votre goût. Je vous préviens d'avance : mon jeu n'est pas facile !
Liens
Source: habr.com