敵の飛行機の移動速度を自由自在に調整してみましょう
続きです
solarplexuss「なんで敵の飛行機が止まってるのかな?
何で敵の飛行機が速度が
10分の1の速度でゆっく〜り左方向に移動しない???
構造体
struct Character {
int x;
int y;
int graphichandle[7];
int graphicnumber;//👈🌞メンバ変数にgraphicnumber を追加しました
int life;
};
を
用いて
struct Character tekinohikouki[10];
を
実行し
敵の飛行機10体のデータを格納するための
構造体変数
tekinohikouki[0]
tekinohikouki[1]
tekinohikouki[2]
tekinohikouki[3]
tekinohikouki[4]
tekinohikouki[5]
tekinohikouki[6]
tekinohikouki[7]
tekinohikouki[8]
tekinohikouki[9]
も
作製したニャンコ🐈
敵の飛行機10体のデータは位置データも含めて
ちゃんと
構造体変数
tekinohikouki[0]
tekinohikouki[1]
tekinohikouki[2]
tekinohikouki[3]
tekinohikouki[4]
tekinohikouki[5]
tekinohikouki[6]
tekinohikouki[7]
tekinohikouki[8]
tekinohikouki[9]
のメンバ変数
に格納されているにゃん」
ぶーにゃん「にゃ〜ん😸」
solarplexuss「
敵の飛行機の移動パターンを
{20,-0.1, 0.1}//🌞前のエピソードの移動パターンの1の部分が全部0.1になっています
{20,-0.1,-0.1} //🌞ですから敵の飛行機は1回の繰り返しで前のエピソードにくらべて10分の1の距離を移動することになるはずです
{20,-0.1, 0.1}
{20,-0.1,-0.1}
にして
前のエピソードの
int tekinohikoukiidoupattern[4][3] = { {20,-1,1},{20,-1,-1},{20,-1,1},{20,-1,-1} };
の代わりに
int tekinohikoukiidoupattern[4][3] = { {20,-0.1, 0.1},{20,-0.1,-0.1},{20,-0.1, 0.1},{20,-0.1,-0.1} };
もちゃんと
実行している
後は
if (repeat > 0) {
for (int i = 0; i < 10; i++) {
if (tekinohikouki[i].life > 0) {
tekinohikouki[i].x = tekinohikouki[i].x + tekinohikoukiidoupattern[m][1];
tekinohikouki[i].y = tekinohikouki[i].y + tekinohikoukiidoupattern[m][2];
}
もちゃんと実行されているので
while{}文のブロック{}内の
命令文が1回実行される度に
tekinohikouki[i].x = tekinohikouki[i].x + tekinohikoukiidoupattern[m][1];
tekinohikouki[i].y = tekinohikouki[i].y + tekinohikoukiidoupattern[m][2];
が実行される
敵の飛行機の移動パターンが{20,-0.1, -0.1}の場合
tekinohikouki[i].x = tekinohikouki[i].x - 0.1;
tekinohikouki[i].y = tekinohikouki[i].y - 0.1;
が実行されるので
tekinohikouki[i].x
tekinohikouki[i].y
の値は0.1ずつ変化するはず
つまり
10回
tekinohikouki[i].x = tekinohikouki[i].x + tekinohikoukiidoupattern[m][1];
tekinohikouki[i].y = tekinohikouki[i].y + tekinohikoukiidoupattern[m][2];
が実行されると
敵の飛行機が
1ドット左に移動するはず
1ドット上に移動するはず
だから
敵の飛行機の移動パターンが{20,-0.1, -0.1}の場合
20回
tekinohikouki[i].x = tekinohikouki[i].x + tekinohikoukiidoupattern[m][1];
tekinohikouki[i].y = tekinohikouki[i].y + tekinohikoukiidoupattern[m][2];
が実行されるので
敵の飛行機が
2ドット左に移動するはず
2ドット上に移動するはず
なんだよん
でも
何で今のプログラムでは敵の飛行機が動かないのん?」
😊😊😊
みなさん
敵の飛行機が
while{}文のブロック{}内の命令文が20回繰り返されると
敵の飛行機の移動パターンが{20,-0.1, -0.1}の場合
左方向に2ドット
上方向に2ドット
敵の飛行機が移動する
👇
#include "DxLib.h"
struct Character {
int x;
int y;
int graphichandle[7];
int graphicnumber;//👈🌞メンバ変数にgraphicnumber を追加しました
int life;
};
//👆🌞Characterの構造体宣言です
int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow)
{
ChangeWindowMode(TRUE); // ウインドウモードに設定します
if (DxLib_Init() == -1) // DXライブラリを初期化処理しています
{
return -1; // DXライブラリの初期化に失敗したら直ちにプログラムを終了します
}
SetDrawScreen(DX_SCREEN_BACK);//👈🌞SetDrawScreen関数です 裏画面に画像を描きます printfDxで表示される文字も裏画面に描かれることになります
struct Character jibunnohikouki;
//👆🌞jibunnohikoukiの構造体変数宣言です
jibunnohikouki.x = 0;
jibunnohikouki.y = 0;
jibunnohikouki.graphichandle[0] = LoadGraph("画像データ\\ソーラーが描いた飛行機.bmp");
jibunnohikouki.graphichandle[1] = LoadGraph("画像データ\\ソーラーが描いた飛行機1.bmp");
jibunnohikouki.graphichandle[2] = LoadGraph("画像データ\\ソーラーが描いた飛行機2.bmp");
jibunnohikouki.graphichandle[3] = LoadGraph("画像データ\\ソーラーが描いた飛行機3.bmp");
jibunnohikouki.graphichandle[4] = LoadGraph("画像データ\\ソーラーが描いた飛行機4.bmp");
jibunnohikouki.graphichandle[5] = LoadGraph("画像データ\\ソーラーが描いた飛行機5.bmp");
jibunnohikouki.graphichandle[6] = LoadGraph("画像データ\\ソーラーが描いた飛行機6.bmp");
jibunnohikouki.life = 1;//👈🌞🌞🌞ここがポイントです🌞🌞🌞
jibunnohikouki.graphicnumber = 0;
//👆 jibunnohikouki.graphicnumberは😋自分の飛行機😋のアニメーションパターンをとりあつかっています
//👆🌞構造体変数jibunnohikoukiのメンバ変数の初期化を行っています
//👆 構造体変数jibunnohikoukiは😋自分の飛行機😋のデータをとりあつかっています
struct Character tekinohikouki[10];
//👆🌞敵の飛行機を10体登場させています
for (int i = 0; i < 10; i++) {
tekinohikouki[i].x = 605;
tekinohikouki[i].y = 35 * i;
tekinohikouki[i].graphichandle[0] = LoadGraph("画像データ\\赤い敵の飛行機1.8.bmp");
tekinohikouki[i].graphichandle[1] = LoadGraph("画像データ\\赤い敵の飛行機1.3.bmp");
tekinohikouki[i].graphichandle[2] = LoadGraph("画像データ\\赤い敵の飛行機2.3.bmp");
tekinohikouki[i].graphichandle[3] = LoadGraph("画像データ\\赤い敵の飛行機3.3.bmp");
tekinohikouki[i].graphichandle[4] = LoadGraph("画像データ\\赤い敵の飛行機4.3.bmp");
tekinohikouki[i].graphichandle[5] = LoadGraph("画像データ\\赤い敵の飛行機5.3.bmp");
tekinohikouki[i].graphichandle[6] = LoadGraph("画像データ\\赤い敵の飛行機6.5.bmp");
tekinohikouki[i].graphicnumber = 128 * GetRand(6);
//👆 tekinohikouki[i].graphicnumberは😋敵の飛行機😋のアニメーションパターンをとりあつかっています
//👆ここです🌞🌞🌞ここでtekinohikouki[i].graphicnumberにランダムに0,128,256,384,512,640,768の値が代入されることになります
tekinohikouki[i].life = 100;//👈🌞🌞🌞敵の飛行機に自分の弾が100発当たると破壊されるようにしました
}
struct Character jibunnotama[2];
//🌞👆自分の弾を2つ作成しています
for (int i = 0; i < 2; i = i + 1) {
jibunnotama[i].x = 0;
jibunnotama[i].y = 0;
jibunnotama[i].graphichandle[0] = LoadGraph("画像データ\\自分の弾.bmp");
jibunnotama[i].life = 0;
}
struct Character bakuhatunohonoo[10];
//👆🌞構造体変数bakuhatuhonoo[0], bakuhatuhonoo[1]…bakuhatuhonoo[9]を作成し爆発の炎のデータを取り扱います
for (int i = 0; i < 10; i++) {
bakuhatunohonoo[i].x = 0;
bakuhatunohonoo[i].y = 0;
bakuhatunohonoo[i].graphichandle[0] = LoadGraph("画像データ\\爆発の炎.bmp");
bakuhatunohonoo[i].graphichandle[1] = LoadGraph("画像データ\\爆発の炎1.bmp");
bakuhatunohonoo[i].graphichandle[2] = LoadGraph("画像データ\\爆発の炎2.bmp");
bakuhatunohonoo[i].graphichandle[3] = LoadGraph("画像データ\\爆発の炎3.bmp");
bakuhatunohonoo[i].graphichandle[4] = LoadGraph("画像データ\\爆発の炎4.bmp");
bakuhatunohonoo[i].graphichandle[5] = LoadGraph("画像データ\\爆発の炎5.bmp");
bakuhatunohonoo[i].graphichandle[6] = LoadGraph("画像データ\\爆発の炎6.bmp");
bakuhatunohonoo[i].life = 0;//🌞🌞🌞 bakuhatunohonoo.lifeを初期化しています
bakuhatunohonoo[i].graphicnumber = 0; //🌞🌞🌞爆発の炎ごとにgraphicnumberを用意して初期化しています
}
struct Character tekinohikoukiwooouhikari;
tekinohikoukiwooouhikari.x = 0;
tekinohikoukiwooouhikari.y = 0;
tekinohikoukiwooouhikari.graphichandle[0] = LoadGraph("画像データ\\赤い敵の飛行機を覆う光.bmp");
tekinohikoukiwooouhikari.life = 0;
struct Character jibunnohikoukinobakuhatunohonoo;
//👆🌞構造体変数jibunnohikoukinobakuhatunohonooを作成し自分の飛行機の爆発の炎のデータを取り扱います
jibunnohikoukinobakuhatunohonoo.x = 0;
jibunnohikoukinobakuhatunohonoo.y = 0;
jibunnohikoukinobakuhatunohonoo.graphichandle[0] = LoadGraph("画像データ\\自分の飛行機の爆発の炎.bmp");
jibunnohikoukinobakuhatunohonoo.graphichandle[1] = LoadGraph("画像データ\\自分の飛行機の爆発の炎1.bmp");
jibunnohikoukinobakuhatunohonoo.graphichandle[2] = LoadGraph("画像データ\\自分の飛行機の爆発の炎2.bmp");
jibunnohikoukinobakuhatunohonoo.graphichandle[3] = LoadGraph("画像データ\\自分の飛行機の爆発の炎3.bmp");
jibunnohikoukinobakuhatunohonoo.graphichandle[4] = LoadGraph("画像データ\\自分の飛行機の爆発の炎4.bmp");
jibunnohikoukinobakuhatunohonoo.graphichandle[5] = LoadGraph("画像データ\\自分の飛行機の爆発の炎5.bmp");
jibunnohikoukinobakuhatunohonoo.graphichandle[6] = LoadGraph("画像データ\\自分の飛行機の爆発の炎6.bmp");
jibunnohikoukinobakuhatunohonoo.life = 0;//🌞🌞🌞 jibunnohikoukinobakuhatunohonoo.lifeを初期化しています
jibunnohikoukinobakuhatunohonoo.graphicnumber = 0; //🌞🌞🌞自分の飛行機の爆発の炎のgraphicnumberを用意して初期化しています
int tsix;//🌞🌞🌞tsixには発射される弾の最初の位置のx座標が代入されることになります tは弾、sは最初、iは位置、xはx座標を表しています
int count = 0;//🌞🌞🌞ここでint型の変数countを作製し0で初期化しました
int tekinohikoukiidoupattern[4][3] = { {20,-0.1, 0.1},{20,-0.1,-0.1},{20,-0.1, 0.1},{20,-0.1,-0.1} };//👈🌞🌞🌞🌞🌞ここです敵の飛行機の移動速度は10分の1になるかな?
int m = 0;
int repeat = tekinohikoukiidoupattern[0][0];
while (CheckHitKey(KEY_INPUT_ESCAPE) == 0 && ProcessMessage() == 0) {
DrawBox(100, 100, 500, 300, GetColor(0, 255, 255), TRUE);
int key = GetJoypadInputState(DX_INPUT_KEY_PAD1);
if (jibunnohikouki.life == 1) {
if (4 <= jibunnohikouki.y && jibunnohikouki.y <= 460) {
if (key & PAD_INPUT_UP) jibunnohikouki.y = jibunnohikouki.y - 4;
}
if (0 <= jibunnohikouki.y && jibunnohikouki.y <= 456) {
if (key & PAD_INPUT_DOWN) jibunnohikouki.y = jibunnohikouki.y + 4;
}
if (4 <= jibunnohikouki.x && jibunnohikouki.x <= 605) {
if (key & PAD_INPUT_LEFT) jibunnohikouki.x = jibunnohikouki.x - 4;
}
if (0 <= jibunnohikouki.x && jibunnohikouki.x <= 601) {
if (key & PAD_INPUT_RIGHT) jibunnohikouki.x = jibunnohikouki.x + 4;
}
}
if (jibunnohikouki.life == 1) {
DrawGraph(jibunnohikouki.x, jibunnohikouki.y, jibunnohikouki.graphichandle[(jibunnohikouki.graphicnumber / 32) % 7], TRUE);
//👆🌞🌞🌞 🌞🌞🌞 🌞🌞🌞 jibunnohikouki.graphicnumberを32で割っているので32分の1のアニメーション速度です🌞🌞🌞 🌞🌞🌞 🌞🌞🌞
jibunnohikouki.graphicnumber = jibunnohikouki.graphicnumber + 1;
}
//👆 jibunnohikouki.lifeに格納されている値が1なら自分の飛行機の画像を描きます
//👆jibunnohikouki.lifeに格納されている値が0なら自分の飛行機の画像が描かれることはありません
if (repeat > 0) {
for (int i = 0; i < 10; i++) {
if (tekinohikouki[i].life > 0) {
tekinohikouki[i].x = tekinohikouki[i].x + tekinohikoukiidoupattern[m][1];
tekinohikouki[i].y = tekinohikouki[i].y + tekinohikoukiidoupattern[m][2];
}
}
repeat = repeat - 1;
}
if (repeat == 0) {
if (m < 4) {
repeat = tekinohikoukiidoupattern[m][0];
m = m + 1;
}
if (m == 4) {
m = 0;
repeat = tekinohikoukiidoupattern[m][0];
}
}
for (int i = 0; i < 10; i++) {
if (tekinohikouki[i].life > 0) {
DrawGraph(tekinohikouki[i].x, tekinohikouki[i].y, tekinohikouki[i].graphichandle[(tekinohikouki[i].graphicnumber) / 128 % 7], TRUE);
tekinohikouki[i].graphicnumber = tekinohikouki[i].graphicnumber + 1;
//🌞🌞🌞 (tekinohikouki[i].graphicnumber)を128で割っているので通常のアニメーション速度の128分の1の速度で画像が切り替わります
//👆🌞🌞🌞ここです すでにtekinohikouki[i].graphicnumberには0,128,256,384,512,640,768の値のうちの1つが代入されているので敵の飛行機, 敵の飛行機1・・・敵の飛行機9はそれぞれ異なるタイミングでアニメーションすることになります
}
}
for (int i = 0; i < 10; i++) {
if (tekinohikouki[i].life > 0) {
if ((jibunnohikouki.x < tekinohikouki[i].x + 35) && (tekinohikouki[i].x < jibunnohikouki.x + 35) && (jibunnohikouki.y + 7 < tekinohikouki[i].y + 20) && (tekinohikouki[i].y < jibunnohikouki.y + 20)) {
jibunnohikouki.life = 0;
tekinohikouki[i].life = 0;
//👆🌞自分の飛行機と敵の飛行機が衝突すると共に消滅することになります
bakuhatunohonoo[i].x = tekinohikouki[i].x;
bakuhatunohonoo[i].y = tekinohikouki[i].y;
bakuhatunohonoo[i].life = 128 + 128 * GetRand(9); //🌞🌞🌞 bakuhatunohonoo[i].lifeに0以上の値を代入しました bakuhatunohonoo[0].life, bakuhatunohonoo[1].life, bakuhatunohonoo[2].life, bakuhatunohonoo[3].life, bakuhatunohonoo[4].life, bakuhatunohonoo[5].life, bakuhatunohonoo[6].life, bakuhatunohonoo[7].life, bakuhatunohonoo[8].life, bakuhatunohonoo[9].lifeにランダムに異なる値を代入することにより爆発する時間をランダムに変化させています
jibunnohikoukinobakuhatunohonoo.x = jibunnohikouki.x;
jibunnohikoukinobakuhatunohonoo.y = jibunnohikouki.y;
jibunnohikoukinobakuhatunohonoo.life = 128 + 128 * GetRand(9); //🌞🌞🌞 jibunnohikoukinobakuhatunohonoo.lifeに0以上の値を代入しました jibunnohikoukinobakuhatunohonoo.lifeにランダムに異なる値を代入することにより自分の飛行機が爆発する時間をランダムに変化させています
}
}
}
for (int i = 0; i < 10; i++) {
if (tekinohikouki[i].life > 0) {
for (int j = 0; j < 2; j++) {
if ((jibunnotama[j].x < tekinohikouki[i].x + 35) && (tekinohikouki[i].x < jibunnotama[j].x + 15) && (jibunnotama[j].y < tekinohikouki[i].y + 20) && (tekinohikouki[i].y < jibunnotama[j].y + 5)) {
jibunnotama[j].life = 0;
tekinohikouki[i].life = tekinohikouki[i].life - 1;
//👆🌞自分の弾と敵の飛行機が衝突すると自分の弾は消滅しtekinohikouki[i].lifeに格納されている値は1減ることになります tekinohikouki[i].lifeに格納されている値が0になると敵の飛行機は消滅することになります
tekinohikoukiwooouhikari.x = tekinohikouki[i].x;
tekinohikoukiwooouhikari.y = tekinohikouki[i].y;
//🌞🌞🌞自分の弾と敵の飛行機がぶつかると敵の飛行機の位置座標がtekinohikoukiwooouhikari.x, tekinohikoukiwooouhikari.yに代入されます
tekinohikoukiwooouhikari.life = 1;
if (tekinohikouki[i].life == 0) {
bakuhatunohonoo[i].x = tekinohikouki[i].x;
bakuhatunohonoo[i].y = tekinohikouki[i].y;
bakuhatunohonoo[i].life = 128 + 128 * GetRand(9); //🌞🌞🌞 bakuhatunohonoo[i].lifeに0以上の値を代入しました bakuhatunohonoo[0].life, bakuhatunohonoo[1].life, bakuhatunohonoo[2].life, bakuhatunohonoo[3].life, bakuhatunohonoo[4].life, bakuhatunohonoo[5].life, bakuhatunohonoo[6].life, bakuhatunohonoo[7].life, bakuhatunohonoo[8].life, bakuhatunohonoo[9].lifeにランダムに異なる値を代入することにより爆発する時間をランダムに変化させています
}
}
}
}
}
if (tekinohikoukiwooouhikari.life > 0) {
SetDrawBlendMode(DX_BLENDMODE_ALPHA, 200);
//👆🌞🌞🌞描画ブレンドモードがアルファブレンドになっています
DrawGraph(tekinohikoukiwooouhikari.x, tekinohikoukiwooouhikari.y, tekinohikoukiwooouhikari.graphichandle[0], TRUE);
SetDrawBlendMode(DX_BLENDMODE_NOBLEND, 0);
tekinohikoukiwooouhikari.life = tekinohikoukiwooouhikari.life - 1;
// 👆🌞🌞🌞描画ブレンドモードをノーブレンドにして描画ブレンドモードを解除しています
}
//👆🌞🌞🌞敵の飛行機を覆う光の画像が描かれます tekinohikoukiwooouhikari.lifeに格納されている値が0になると敵の飛行機を覆う光の画像が描かれることはありません
for (int i = 0; i < 10; i++) {
if (bakuhatunohonoo[i].life > 0) {
DrawGraph(bakuhatunohonoo[i].x, bakuhatunohonoo[i].y, bakuhatunohonoo[i].graphichandle[(bakuhatunohonoo[i].graphicnumber / 32) % 7], TRUE);
//👆🌞🌞🌞 🌞🌞🌞 🌞🌞bakuhatunohonoo[i].graphicnumberを32で割っているので32分の1のアニメーション速度です🌞🌞🌞 🌞🌞🌞 🌞🌞🌞
bakuhatunohonoo[i].graphicnumber = bakuhatunohonoo[i].graphicnumber + 1;
//👆🌞🌞🌞爆発の炎がアニメーションするよう設定が行われています
bakuhatunohonoo[i].life = bakuhatunohonoo[i].life - 1;
}
//👆 bakuhatunohonoo[i].lifeに格納されている値が1なら爆発の炎の画像を描きます
//👆 bakuhatunohonoo[i].lifeに格納されている値が0なら爆発の炎の画像が描かれることはありません
}
if (jibunnohikoukinobakuhatunohonoo.life > 0) {
DrawGraph(jibunnohikoukinobakuhatunohonoo.x, jibunnohikoukinobakuhatunohonoo.y, jibunnohikoukinobakuhatunohonoo.graphichandle[(jibunnohikoukinobakuhatunohonoo.graphicnumber / 32) % 7], TRUE);
//👆🌞🌞🌞 🌞🌞🌞 🌞🌞 jibunnohikoukinobakuhatunohonoo.graphicnumberを32で割っているので32分の1のアニメーション速度です🌞🌞🌞 🌞🌞🌞 🌞🌞🌞
jibunnohikoukinobakuhatunohonoo.graphicnumber = jibunnohikoukinobakuhatunohonoo.graphicnumber + 1;
//👆🌞🌞🌞自分の飛行機の爆発の炎がアニメーションするよう設定が行われています
jibunnohikoukinobakuhatunohonoo.life = jibunnohikoukinobakuhatunohonoo.life - 1;
}
//👆 jibunnohikoukinobakuhatunohonoo.lifeに格納されている値が1以上なら自分の飛行機の爆発の炎の画像を描きます
//👆 jibunnohikoukinobakuhatunohonoo.lifeに格納されている値が0なら自分の飛行機の爆発の炎の画像が描かれることはありません
if ((key & PAD_INPUT_A) && (count == 0)) {
for (int i = 0; i < 2; i = i + 1) {
if (jibunnotama[i].life == 0) {
jibunnotama[i].x = jibunnohikouki.x + 35;
tsix = jibunnotama[i].x;
jibunnotama[i].y = jibunnohikouki.y + 10;
jibunnotama[i].life = 1;
break;
}
}
count = 10;
}
if (count > 0) { count = count - 1; }
for (int i = 0; i < 2; i = i + 1) {
if (jibunnotama[i].life == 1) {
//🌞🌞🌞 jibunnotama[i].lifeに1が代入されていると自分の弾がゲーム画面に表示されることになります jibunnotama[i].lifeに0が代入されていると自分の弾がゲーム画面に表示されることはありません
DrawGraph(jibunnotama[i].x, jibunnotama[i].y, jibunnotama[i].graphichandle[0], TRUE);
jibunnotama[i].x = jibunnotama[i].x + 10;
if (jibunnotama[i].x - tsix > 640)
//🌞🌞🌞発射された弾の位置のx座標が発射されたときの最初の弾の位置のx座標から640を超えて離れると条件式jibunnotama[i].x - tsix > 640は真の値1をとることになります
//🌞🌞🌞🌞🌞👆 tsixにはZボタンが押されたときの自分の弾のいる位置のx座標を記憶していたのでjibunnotama[i].xがZボタンが押されたときの自分の弾のいる位置から640ドット離れた時jibunnotama[i].x -tsix> 640は真の値1を持つことになります
jibunnotama[i].life = 0;
}
}
ScreenFlip();
ClearDrawScreen();
};
DxLib_End(); // DXライブラリの使用を終了します DXライブラリの使用しているメモリ領域が解放されます
return 0; // プログラムを終了します
}
デバッグなしで実行をしてから一度プログラムを終了し
生成されたexeファイルをハードディスクから探し出しクリックする方法により得られたプログラムの実行結果はこちらです
👇
https://www.youtube.com/watch?v=qn3zva3W144
solarplexuss「?????
やっぱり敵の飛行機が動かな〜い
理由は不明だ」
ソーラー「ううーん」
solarplexuss「ううーん」
ソーラー「ううーん」
solarplexuss「うう ううん💖」
solarplexuss「ううーん」
ソーラー「実は
solarplexussさんのしゃべったことの中に全部原因が含まれているんだよ」
solarplexuss「えびぃ?」
ソーラー「
敵の飛行機の移動パターンが{20,-0.1, -0.1}の場合
tekinohikouki[i].x = tekinohikouki[i].x - 0.1;
tekinohikouki[i].y = tekinohikouki[i].y - 0.1;
が実行されるんだけど
構造体
struct Character {
int x;//👈🌞🌞🌞ここに注目 int型が用いられています
int y; //👈🌞🌞🌞ここに注目 int型が用いられています
int graphichandle[7];
int graphicnumber;//👈🌞メンバ変数にgraphicnumber を追加しました
int life;
};
を
用いて
struct Character tekinohikouki[10];
を
実行し
敵の飛行機のデータを格納するための
構造体変数
tekinohikouki[0]
tekinohikouki[1]
tekinohikouki[2]
tekinohikouki[3]
tekinohikouki[4]
tekinohikouki[5]
tekinohikouki[6]
tekinohikouki[7]
tekinohikouki[8]
tekinohikouki[9]
を作製したから
構造体変数のメンバ変数
tekinohikouki[i].x
tekinohikouki[i].y
は
int型の変数なんだ
(構造体
struct Character {
int x;//👈🌞🌞🌞ここに注目 int型が用いられています
int y; //👈🌞🌞🌞ここに注目 int型が用いられています
int graphichandle[7];
int graphicnumber;//👈🌞メンバ変数にgraphicnumber を追加しました
int life;
};
で
int x;//👈🌞🌞🌞ここに注目 int型が用いられています
int y; //👈🌞🌞🌞ここに注目 int型が用いられています
が用いられているので
tekinohikouki[i].x
tekinohikouki[i].y
は
int型の変数となります)
だから
int型の変数にdouble型の形式でメモリに格納されている実数値-0.1を足す
tekinohikouki[i].x = tekinohikouki[i].x - 0.1;
tekinohikouki[i].y = tekinohikouki[i].y - 0.1;
は
tekinohikouki[i].x (int型の変数)= tekinohikouki[i].x (int型の変数)- 0.1(double型の形式でメモリに格納されている実数値);
tekinohikouki[i].y (int型の変数) = tekinohikouki[i].y (int型の変数) -0.1 (double型の形式でメモリに格納されている実数値);
なんです
ここでは
int型の変数とdouble型の形式でメモリに格納されている実数値の足し算が実行されることになります
int型の変数に格納されている値は
整数値で
int型の形式でメモリに格納されています
つまり
tekinohikouki[i].x (int型の変数)= tekinohikouki[i].x (int型の変数)- 0.1(double型の形式でメモリに格納されている実数値)
tekinohikouki[i].y (int型の変数) = tekinohikouki[i].y (int型の変数) -0.1 (double型の形式でメモリに格納されている実数値);
は
tekinohikouki[i].x (int型の形式でメモリに格納されている整数値)= tekinohikouki[i].x (int型の形式でメモリに格納されている整数値)- 0.1(double型の形式でメモリに格納されている実数値);
tekinohikouki[i].y (int型の形式でメモリに格納されている整数値) = tekinohikouki[i].y (int型の形式でメモリに格納されている整数値) -0.1 (double型の形式でメモリに格納されている実数値);
となります
int型の形式でメモリに格納されている整数値
と
double型の形式でメモリに格納されている実数値
の計算では
double型の形式でメモリに格納されている実数値
は
少数点以下は切り捨てられ
int型の形式でメモリに格納されている整数値
に変換されます
だから
double型の形式でメモリに格納されている実数値-0.1
は
少数点以下は切り捨てられ
int型の形式でメモリに格納されている整数値-0
に変換されます
ですので
tekinohikouki[i].x (int型の形式でメモリに格納されている整数値)= tekinohikouki[i].x (int型の形式でメモリに格納されている整数値)- 0.1 (double型の形式でメモリに格納されている実数値);
tekinohikouki[i].y (int型の形式でメモリに格納されている整数値) = tekinohikouki[i].y (int型の形式でメモリに格納されている整数値) -0.1 (double型の形式でメモリに格納されている実数値);
は
tekinohikouki[i].x = tekinohikouki[i].x - 0.1;
tekinohikouki[i].y = tekinohikouki[i].y - 0.1;
でなく
tekinohikouki[i].x = tekinohikouki[i].x - 0;
tekinohikouki[i].y = tekinohikouki[i].y - 0;
が実行されることになります
つまり
tekinohikouki[i].x
tekinohikouki[i].y
に格納されている値は変化しないんだ
だから
敵の飛行機は移動しなくなるんだ
だから
構造体
struct Character {
int x;
int y;
int graphichandle[7];
int graphicnumber;//👈🌞メンバ変数にgraphicnumber を追加しました
int life;
};
を
struct Character {
double x;//👈🌞🌞🌞ここに注目intをdoubleに変更しました
double y; //👈🌞🌞🌞ここに注目intをdoubleに変更しました
int graphichandle[7];
int graphicnumber;//👈🌞メンバ変数にgraphicnumber を追加しました
int life;
};
に変更して
tekinohikouki[i].x
tekinohikouki[i].y
を
double型の変数に変更する必要があります
double型の変数に実数-0.1を足す
tekinohikouki[i].x = tekinohikouki[i].x - 0.1;
tekinohikouki[i].y = tekinohikouki[i].y - 0.1;
は
tekinohikouki[i].x (double型の変数)= tekinohikouki[i].x (int型の変数)- 0.1(double型の形式でメモリに格納されている実数値);
tekinohikouki[i].y (double型の変数) = tekinohikouki[i].y (int型の変数) -0.1 (double型の形式でメモリに格納されている実数値);
となり
double型の変数とdouble型の形式でメモリに格納されている実数値の足し算が実行されることになります
double型の変数に格納されている値は
実数値で
double型の形式でメモリに格納されています
つまり
tekinohikouki[i].x (double型の変数)= tekinohikouki[i].x (double型の変数)- 0.1((double型の形式でメモリに格納されている実数値);
tekinohikouki[i].y (int型の変数) = tekinohikouki[i].y (double型の変数) -0.1 (double型の形式でメモリに格納されている実数値);
は
tekinohikouki[i].x (double型の形式でメモリに格納されている実数値)= tekinohikouki[i].x (double型の形式でメモリに格納されている実数値)- 0.1(double型の形式でメモリに格納されている実数値);
tekinohikouki[i].y (double型の形式でメモリに格納されている実数値) = tekinohikouki[i].y (double型の形式でメモリに格納されている実数値) -0.1 (double型の形式でメモリに格納されている実数値);
となります
double型の形式でメモリに格納されている実数値
と
double型の形式でメモリに格納されている実数値
の計算では
計算も普通におこなわれ
計算結果も
double型の形式でメモリに格納されることになります
だから
tekinohikouki[i].x = tekinohikouki[i].x - 0.1;
tekinohikouki[i].y = tekinohikouki[i].y - 0.1;
が実行されると
tekinohikouki[i].x
tekinohikouki[i].y
に格納されている値は
0.1ずつ減ることになります」
solarplexuss「
おおう
そういう仕組みなんだ
これで
10回
tekinohikouki[i].x = tekinohikouki[i].x + tekinohikoukiidoupattern[m][1];
tekinohikouki[i].y = tekinohikouki[i].y + tekinohikoukiidoupattern[m][2];
が実行されると
敵の飛行機が
-0.1×10=-1ドット(左に1ドット)
-0.1×10=-1ドット(上に1ドット)
移動することになるんだね」
マックス「おおっ そういうことか」
ソーラー「
といいたいところなんだけど
実は・・・・・
今のプログラムでは
が実行されているので
intの変数
tekinohikoukiidoupattern[0][0]
tekinohikoukiidoupattern[0][1]
tekinohikoukiidoupattern[0][2]
tekinohikoukiidoupattern[1][0]
tekinohikoukiidoupattern[1][1]
tekinohikoukiidoupattern[1][2]
tekinohikoukiidoupattern[2][0]
tekinohikoukiidoupattern[2][1]
tekinohikoukiidoupattern[2][2]
tekinohikoukiidoupattern[3][0]
tekinohikoukiidoupattern[3][1]
tekinohikoukiidoupattern[3][2]
に
20
-0.1
0.1
20
-0.1
-0.1
20
-0.1
0.1
20
-0.1
-0.1
が代入されることになります
が!!」
solarplexuss「が!!」
ソーラー「int型の変数には整数値しか格納できなくて
実数値を代入しようとすると
実数値の小数点以下の部分は切り捨てられ
整数値のみが格納されることになります
ですので
実際には
int型の変数である
tekinohikoukiidoupattern[0][0]
tekinohikoukiidoupattern[0][1]
tekinohikoukiidoupattern[0][2]
tekinohikoukiidoupattern[1][0]
tekinohikoukiidoupattern[1][1]
tekinohikoukiidoupattern[1][2]
tekinohikoukiidoupattern[2][0]
tekinohikoukiidoupattern[2][1]
tekinohikoukiidoupattern[2][2]
tekinohikoukiidoupattern[3][0]
tekinohikoukiidoupattern[3][1]
tekinohikoukiidoupattern[3][2]
に
20
-0.1
0.1
20
-0.1
-0.1
20
-0.1
0.1
20
-0.1
-0.1
が代入されるのではなく
20
-0
0
20
-0
-0
20
-0
0
20
-0
-0
が代入されています
つまり
たとえ
構造体
struct Character {
int x;
int y;
int graphichandle[7];
int graphicnumber;//👈🌞メンバ変数にgraphicnumber を追加しました
int life;
};
を
struct Character {
double x;//👈🌞🌞🌞ここに注目intをdoubleに変更しました
double y; //👈🌞🌞🌞ここに注目intをdoubleに変更しました
int graphichandle[7];
int graphicnumber;//👈🌞メンバ変数にgraphicnumber を追加しました
int life;
};
に変更して
tekinohikouki[i].x
tekinohikouki[i].y
を
double型の変数に変更したとしても
while{}文のブロック{}内の
命令文が1回実行される度に
tekinohikouki[i].x = tekinohikouki[i].x + tekinohikoukiidoupattern[m][1];
tekinohikouki[i].y = tekinohikouki[i].y + tekinohikoukiidoupattern[m][2];
が実行されると
tekinohikouki[i].x = tekinohikouki[i].x - 0.1;
tekinohikouki[i].y = tekinohikouki[i].y - 0.1;
は実行されず
tekinohikouki[i].x = tekinohikouki[i].x - 0;
tekinohikouki[i].y = tekinohikouki[i].y - 0;
が
実行されることになります
つまり敵の飛行機は移動しないんだ
だから
double型の変数には実数値を格納することができるので
を実行するのではなく
を実行することになります
そうすれば
double型の変数である
tekinohikoukiidoupattern[0][0]
tekinohikoukiidoupattern[0][1]
tekinohikoukiidoupattern[0][2]
tekinohikoukiidoupattern[1][0]
tekinohikoukiidoupattern[1][1]
tekinohikoukiidoupattern[1][2]
tekinohikoukiidoupattern[2][0]
tekinohikoukiidoupattern[2][1]
tekinohikoukiidoupattern[2][2]
tekinohikoukiidoupattern[3][0]
tekinohikoukiidoupattern[3][1]
tekinohikoukiidoupattern[3][2]
に
20
-0.1
0.1
20
-0.1
-0.1
20
-0.1
0.1
20
-0.1
-0.1
が代入されることになります
ですので
tekinohikouki[i].x = tekinohikouki[i].x + tekinohikoukiidoupattern[m][1];
tekinohikouki[i].y = tekinohikouki[i].y + tekinohikoukiidoupattern[m][2];
は
tekinohikouki[i].x (double型の形式でメモリに格納されている実数値)= tekinohikouki[i].x (double型の形式でメモリに格納されている実数値)- 0.1(double型の形式でメモリに格納されている実数値);
tekinohikouki[i].y (double型の形式でメモリに格納されている実数値) = tekinohikouki[i].y (double型の形式でメモリに格納されている実数値) -0.1 (double型の形式でメモリに格納されている実数値);
となります
double型の形式でメモリに格納されている実数値
と
double型の形式でメモリに格納されている実数値
の計算では
計算も普通におこなわれ
計算結果も
double型の形式でメモリに格納されることになります
ですので
敵の飛行機の移動パターンが{20,-0.1, -0.1}の場合
while{}文のブロック{}内の
命令文が1回実行される度に
tekinohikouki[i].x = tekinohikouki[i].x + tekinohikoukiidoupattern[m][1];
tekinohikouki[i].y = tekinohikouki[i].y + tekinohikoukiidoupattern[m][2];
が実行されると
tekinohikouki[i].x = tekinohikouki[i].x - 0.1;
tekinohikouki[i].y = tekinohikouki[i].y - 0.1;
が実行され
tekinohikouki[i].x
tekinohikouki[i].y
に格納されている値は
0.1ずつ減少することになります
つまり敵の飛行機は
敵の飛行機の移動パターンが{20,-0.1, -0.1}の場合
20回
tekinohikouki[i].x = tekinohikouki[i].x + tekinohikoukiidoupattern[m][1];
tekinohikouki[i].y = tekinohikouki[i].y + tekinohikoukiidoupattern[m][2];
が実行されるので
敵の飛行機が
-0.1 ×20=-2ドット(左に)
-0.1 ×20= 2ドット(上に)移動することになります」
solarplexuss「ああおおうう
int型の形式でデータをメモリに格納するのと
double型の形式でデータをメモリに格納するのとでは
こんなに違いがでてくるんだね」
ソーラー「そうだね
それでは
さきほどのプログラムの
構造体
struct Character {
int x;
int y;
int graphichandle[7];
int graphicnumber;//👈🌞メンバ変数にgraphicnumber を追加しました
int life;
};
を
struct Character {
double x;//👈🌞🌞🌞ここに注目intをdoubleに変更しました
double y; //👈🌞🌞🌞ここに注目intをdoubleに変更しました
int graphichandle[7];
int graphicnumber;//👈🌞メンバ変数にgraphicnumber を追加しました
int life;
};
に変更して
int tekinohikoukiidoupattern[4][3] = { {20,-0.1, 0.1},{20,-0.1,-0.1},{20,-0.1, 0.1},{20,-0.1,-0.1} };
を
double tekinohikoukiidoupattern[4][3] = { {20,-0.1, 0.1},{20,-0.1,-0.1},{20,-0.1, 0.1},{20,-0.1,-0.1} };
に変更したプログラムを実行してみたいと思います
さて敵の飛行機は動くことになるかな?」
👇
#include "DxLib.h"
struct Character {
double x;
double y;
int graphichandle[7];
int graphicnumber;//👈🌞メンバ変数にgraphicnumber を追加しました
int life;
};
//👆🌞Characterの構造体宣言です
int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow)
{
ChangeWindowMode(TRUE); // ウインドウモードに設定します
if (DxLib_Init() == -1) // DXライブラリを初期化処理しています
{
return -1; // DXライブラリの初期化に失敗したら直ちにプログラムを終了します
}
SetDrawScreen(DX_SCREEN_BACK);//👈🌞SetDrawScreen関数です 裏画面に画像を描きます printfDxで表示される文字も裏画面に描かれることになります
struct Character jibunnohikouki;
//👆🌞jibunnohikoukiの構造体変数宣言です
jibunnohikouki.x = 0;
jibunnohikouki.y = 0;
jibunnohikouki.graphichandle[0] = LoadGraph("画像データ\\ソーラーが描いた飛行機.bmp");
jibunnohikouki.graphichandle[1] = LoadGraph("画像データ\\ソーラーが描いた飛行機1.bmp");
jibunnohikouki.graphichandle[2] = LoadGraph("画像データ\\ソーラーが描いた飛行機2.bmp");
jibunnohikouki.graphichandle[3] = LoadGraph("画像データ\\ソーラーが描いた飛行機3.bmp");
jibunnohikouki.graphichandle[4] = LoadGraph("画像データ\\ソーラーが描いた飛行機4.bmp");
jibunnohikouki.graphichandle[5] = LoadGraph("画像データ\\ソーラーが描いた飛行機5.bmp");
jibunnohikouki.graphichandle[6] = LoadGraph("画像データ\\ソーラーが描いた飛行機6.bmp");
jibunnohikouki.life = 1;//👈🌞🌞🌞ここがポイントです🌞🌞🌞
jibunnohikouki.graphicnumber = 0;
//👆 jibunnohikouki.graphicnumberは😋自分の飛行機😋のアニメーションパターンをとりあつかっています
//👆🌞構造体変数jibunnohikoukiのメンバ変数の初期化を行っています
//👆 構造体変数jibunnohikoukiは😋自分の飛行機😋のデータをとりあつかっています
struct Character tekinohikouki[10];
//👆🌞敵の飛行機を10体登場させています
for (int i = 0; i < 10; i++) {
tekinohikouki[i].x = 605;
tekinohikouki[i].y = 35 * i;
tekinohikouki[i].graphichandle[0] = LoadGraph("画像データ\\赤い敵の飛行機1.8.bmp");
tekinohikouki[i].graphichandle[1] = LoadGraph("画像データ\\赤い敵の飛行機1.3.bmp");
tekinohikouki[i].graphichandle[2] = LoadGraph("画像データ\\赤い敵の飛行機2.3.bmp");
tekinohikouki[i].graphichandle[3] = LoadGraph("画像データ\\赤い敵の飛行機3.3.bmp");
tekinohikouki[i].graphichandle[4] = LoadGraph("画像データ\\赤い敵の飛行機4.3.bmp");
tekinohikouki[i].graphichandle[5] = LoadGraph("画像データ\\赤い敵の飛行機5.3.bmp");
tekinohikouki[i].graphichandle[6] = LoadGraph("画像データ\\赤い敵の飛行機6.5.bmp");
tekinohikouki[i].graphicnumber = 128 * GetRand(6);
//👆 tekinohikouki[i].graphicnumberは😋敵の飛行機😋のアニメーションパターンをとりあつかっています
//👆ここです🌞🌞🌞ここでtekinohikouki[i].graphicnumberにランダムに0,128,256,384,512,640,768の値が代入されることになります
tekinohikouki[i].life = 100;//👈🌞🌞🌞敵の飛行機に自分の弾が100発当たると破壊されるようにしました
}
struct Character jibunnotama[2];
//🌞👆自分の弾を2つ作成しています
for (int i = 0; i < 2; i = i + 1) {
jibunnotama[i].x = 0;
jibunnotama[i].y = 0;
jibunnotama[i].graphichandle[0] = LoadGraph("画像データ\\自分の弾.bmp");
jibunnotama[i].life = 0;
}
struct Character bakuhatunohonoo[10];
//👆🌞構造体変数bakuhatuhonoo[0], bakuhatuhonoo[1]…bakuhatuhonoo[9]を作成し爆発の炎のデータを取り扱います
for (int i = 0; i < 10; i++) {
bakuhatunohonoo[i].x = 0;
bakuhatunohonoo[i].y = 0;
bakuhatunohonoo[i].graphichandle[0] = LoadGraph("画像データ\\爆発の炎.bmp");
bakuhatunohonoo[i].graphichandle[1] = LoadGraph("画像データ\\爆発の炎1.bmp");
bakuhatunohonoo[i].graphichandle[2] = LoadGraph("画像データ\\爆発の炎2.bmp");
bakuhatunohonoo[i].graphichandle[3] = LoadGraph("画像データ\\爆発の炎3.bmp");
bakuhatunohonoo[i].graphichandle[4] = LoadGraph("画像データ\\爆発の炎4.bmp");
bakuhatunohonoo[i].graphichandle[5] = LoadGraph("画像データ\\爆発の炎5.bmp");
bakuhatunohonoo[i].graphichandle[6] = LoadGraph("画像データ\\爆発の炎6.bmp");
bakuhatunohonoo[i].life = 0;//🌞🌞🌞 bakuhatunohonoo.lifeを初期化しています
bakuhatunohonoo[i].graphicnumber = 0; //🌞🌞🌞爆発の炎ごとにgraphicnumberを用意して初期化しています
}
struct Character tekinohikoukiwooouhikari;
tekinohikoukiwooouhikari.x = 0;
tekinohikoukiwooouhikari.y = 0;
tekinohikoukiwooouhikari.graphichandle[0] = LoadGraph("画像データ\\赤い敵の飛行機を覆う光.bmp");
tekinohikoukiwooouhikari.life = 0;
struct Character jibunnohikoukinobakuhatunohonoo;
//👆🌞構造体変数jibunnohikoukinobakuhatunohonooを作成し自分の飛行機の爆発の炎のデータを取り扱います
jibunnohikoukinobakuhatunohonoo.x = 0;
jibunnohikoukinobakuhatunohonoo.y = 0;
jibunnohikoukinobakuhatunohonoo.graphichandle[0] = LoadGraph("画像データ\\自分の飛行機の爆発の炎.bmp");
jibunnohikoukinobakuhatunohonoo.graphichandle[1] = LoadGraph("画像データ\\自分の飛行機の爆発の炎1.bmp");
jibunnohikoukinobakuhatunohonoo.graphichandle[2] = LoadGraph("画像データ\\自分の飛行機の爆発の炎2.bmp");
jibunnohikoukinobakuhatunohonoo.graphichandle[3] = LoadGraph("画像データ\\自分の飛行機の爆発の炎3.bmp");
jibunnohikoukinobakuhatunohonoo.graphichandle[4] = LoadGraph("画像データ\\自分の飛行機の爆発の炎4.bmp");
jibunnohikoukinobakuhatunohonoo.graphichandle[5] = LoadGraph("画像データ\\自分の飛行機の爆発の炎5.bmp");
jibunnohikoukinobakuhatunohonoo.graphichandle[6] = LoadGraph("画像データ\\自分の飛行機の爆発の炎6.bmp");
jibunnohikoukinobakuhatunohonoo.life = 0;//🌞🌞🌞 jibunnohikoukinobakuhatunohonoo.lifeを初期化しています
jibunnohikoukinobakuhatunohonoo.graphicnumber = 0; //🌞🌞🌞自分の飛行機の爆発の炎のgraphicnumberを用意して初期化しています
int tsix;//🌞🌞🌞tsixには発射される弾の最初の位置のx座標が代入されることになります tは弾、sは最初、iは位置、xはx座標を表しています
int count = 0;//🌞🌞🌞ここでint型の変数countを作製し0で初期化しました
double tekinohikoukiidoupattern[4][3] = { {20,-0.1, 0.1},{20,-0.1,-0.1},{20,-0.1, 0.1},{20,-0.1,-0.1} };//👈🌞🌞🌞🌞🌞ここです敵の飛行機の移動速度は10分の1になるかな?
int m = 0;
int repeat = tekinohikoukiidoupattern[0][0];
while (CheckHitKey(KEY_INPUT_ESCAPE) == 0 && ProcessMessage() == 0) {
DrawBox(100, 100, 500, 300, GetColor(0, 255, 255), TRUE);
int key = GetJoypadInputState(DX_INPUT_KEY_PAD1);
if (jibunnohikouki.life == 1) {
if (4 <= jibunnohikouki.y && jibunnohikouki.y <= 460) {
if (key & PAD_INPUT_UP) jibunnohikouki.y = jibunnohikouki.y - 4;
}
if (0 <= jibunnohikouki.y && jibunnohikouki.y <= 456) {
if (key & PAD_INPUT_DOWN) jibunnohikouki.y = jibunnohikouki.y + 4;
}
if (4 <= jibunnohikouki.x && jibunnohikouki.x <= 605) {
if (key & PAD_INPUT_LEFT) jibunnohikouki.x = jibunnohikouki.x - 4;
}
if (0 <= jibunnohikouki.x && jibunnohikouki.x <= 601) {
if (key & PAD_INPUT_RIGHT) jibunnohikouki.x = jibunnohikouki.x + 4;
}
}
if (jibunnohikouki.life == 1) {
DrawGraph(jibunnohikouki.x, jibunnohikouki.y, jibunnohikouki.graphichandle[(jibunnohikouki.graphicnumber / 32) % 7], TRUE);
//👆🌞🌞🌞 🌞🌞🌞 🌞🌞🌞 jibunnohikouki.graphicnumberを32で割っているので32分の1のアニメーション速度です🌞🌞🌞 🌞🌞🌞 🌞🌞🌞
jibunnohikouki.graphicnumber = jibunnohikouki.graphicnumber + 1;
}
//👆 jibunnohikouki.lifeに格納されている値が1なら自分の飛行機の画像を描きます
//👆jibunnohikouki.lifeに格納されている値が0なら自分の飛行機の画像が描かれることはありません
if (repeat > 0) {
for (int i = 0; i < 10; i++) {
if (tekinohikouki[i].life > 0) {
tekinohikouki[i].x = tekinohikouki[i].x + tekinohikoukiidoupattern[m][1];
tekinohikouki[i].y = tekinohikouki[i].y + tekinohikoukiidoupattern[m][2];
}
}
repeat = repeat - 1;
}
if (repeat == 0) {
if (m < 4) {
repeat = tekinohikoukiidoupattern[m][0];
m = m + 1;
}
if (m == 4) {
m = 0;
repeat = tekinohikoukiidoupattern[m][0];
}
}
for (int i = 0; i < 10; i++) {
if (tekinohikouki[i].life > 0) {
DrawGraph(tekinohikouki[i].x, tekinohikouki[i].y, tekinohikouki[i].graphichandle[(tekinohikouki[i].graphicnumber) / 128 % 7], TRUE);
tekinohikouki[i].graphicnumber = tekinohikouki[i].graphicnumber + 1;
//🌞🌞🌞 (tekinohikouki[i].graphicnumber)を128で割っているので通常のアニメーション速度の128分の1の速度で画像が切り替わります
//👆🌞🌞🌞ここです すでにtekinohikouki[i].graphicnumberには0,128,256,384,512,640,768の値のうちの1つが代入されているので敵の飛行機, 敵の飛行機1・・・敵の飛行機9はそれぞれ異なるタイミングでアニメーションすることになります
}
}
for (int i = 0; i < 10; i++) {
if (tekinohikouki[i].life > 0) {
if ((jibunnohikouki.x < tekinohikouki[i].x + 35) && (tekinohikouki[i].x < jibunnohikouki.x + 35) && (jibunnohikouki.y + 7 < tekinohikouki[i].y + 20) && (tekinohikouki[i].y < jibunnohikouki.y + 20)) {
jibunnohikouki.life = 0;
tekinohikouki[i].life = 0;
//👆🌞自分の飛行機と敵の飛行機が衝突すると共に消滅することになります
bakuhatunohonoo[i].x = tekinohikouki[i].x;
bakuhatunohonoo[i].y = tekinohikouki[i].y;
bakuhatunohonoo[i].life = 128 + 128 * GetRand(9); //🌞🌞🌞 bakuhatunohonoo[i].lifeに0以上の値を代入しました bakuhatunohonoo[0].life, bakuhatunohonoo[1].life, bakuhatunohonoo[2].life, bakuhatunohonoo[3].life, bakuhatunohonoo[4].life, bakuhatunohonoo[5].life, bakuhatunohonoo[6].life, bakuhatunohonoo[7].life, bakuhatunohonoo[8].life, bakuhatunohonoo[9].lifeにランダムに異なる値を代入することにより爆発する時間をランダムに変化させています
jibunnohikoukinobakuhatunohonoo.x = jibunnohikouki.x;
jibunnohikoukinobakuhatunohonoo.y = jibunnohikouki.y;
jibunnohikoukinobakuhatunohonoo.life = 128 + 128 * GetRand(9); //🌞🌞🌞 jibunnohikoukinobakuhatunohonoo.lifeに0以上の値を代入しました jibunnohikoukinobakuhatunohonoo.lifeにランダムに異なる値を代入することにより自分の飛行機が爆発する時間をランダムに変化させています
}
}
}
for (int i = 0; i < 10; i++) {
if (tekinohikouki[i].life > 0) {
for (int j = 0; j < 2; j++) {
if ((jibunnotama[j].x < tekinohikouki[i].x + 35) && (tekinohikouki[i].x < jibunnotama[j].x + 15) && (jibunnotama[j].y < tekinohikouki[i].y + 20) && (tekinohikouki[i].y < jibunnotama[j].y + 5)) {
jibunnotama[j].life = 0;
tekinohikouki[i].life = tekinohikouki[i].life - 1;
//👆🌞自分の弾と敵の飛行機が衝突すると自分の弾は消滅しtekinohikouki[i].lifeに格納されている値は1減ることになります tekinohikouki[i].lifeに格納されている値が0になると敵の飛行機は消滅することになります
tekinohikoukiwooouhikari.x = tekinohikouki[i].x;
tekinohikoukiwooouhikari.y = tekinohikouki[i].y;
//🌞🌞🌞自分の弾と敵の飛行機がぶつかると敵の飛行機の位置座標がtekinohikoukiwooouhikari.x, tekinohikoukiwooouhikari.yに代入されます
tekinohikoukiwooouhikari.life = 1;
if (tekinohikouki[i].life == 0) {
bakuhatunohonoo[i].x = tekinohikouki[i].x;
bakuhatunohonoo[i].y = tekinohikouki[i].y;
bakuhatunohonoo[i].life = 128 + 128 * GetRand(9); //🌞🌞🌞 bakuhatunohonoo[i].lifeに0以上の値を代入しました bakuhatunohonoo[0].life, bakuhatunohonoo[1].life, bakuhatunohonoo[2].life, bakuhatunohonoo[3].life, bakuhatunohonoo[4].life, bakuhatunohonoo[5].life, bakuhatunohonoo[6].life, bakuhatunohonoo[7].life, bakuhatunohonoo[8].life, bakuhatunohonoo[9].lifeにランダムに異なる値を代入することにより爆発する時間をランダムに変化させています
}
}
}
}
}
if (tekinohikoukiwooouhikari.life > 0) {
SetDrawBlendMode(DX_BLENDMODE_ALPHA, 200);
//👆🌞🌞🌞描画ブレンドモードがアルファブレンドになっています
DrawGraph(tekinohikoukiwooouhikari.x, tekinohikoukiwooouhikari.y, tekinohikoukiwooouhikari.graphichandle[0], TRUE);
SetDrawBlendMode(DX_BLENDMODE_NOBLEND, 0);
tekinohikoukiwooouhikari.life = tekinohikoukiwooouhikari.life - 1;
// 👆🌞🌞🌞描画ブレンドモードをノーブレンドにして描画ブレンドモードを解除しています
}
//👆🌞🌞🌞敵の飛行機を覆う光の画像が描かれます tekinohikoukiwooouhikari.lifeに格納されている値が0になると敵の飛行機を覆う光の画像が描かれることはありません
for (int i = 0; i < 10; i++) {
if (bakuhatunohonoo[i].life > 0) {
DrawGraph(bakuhatunohonoo[i].x, bakuhatunohonoo[i].y, bakuhatunohonoo[i].graphichandle[(bakuhatunohonoo[i].graphicnumber / 32) % 7], TRUE);
//👆🌞🌞🌞 🌞🌞🌞 🌞🌞bakuhatunohonoo[i].graphicnumberを32で割っているので32分の1のアニメーション速度です🌞🌞🌞 🌞🌞🌞 🌞🌞🌞
bakuhatunohonoo[i].graphicnumber = bakuhatunohonoo[i].graphicnumber + 1;
//👆🌞🌞🌞爆発の炎がアニメーションするよう設定が行われています
bakuhatunohonoo[i].life = bakuhatunohonoo[i].life - 1;
}
//👆 bakuhatunohonoo[i].lifeに格納されている値が1なら爆発の炎の画像を描きます
//👆 bakuhatunohonoo[i].lifeに格納されている値が0なら爆発の炎の画像が描かれることはありません
}
if (jibunnohikoukinobakuhatunohonoo.life > 0) {
DrawGraph(jibunnohikoukinobakuhatunohonoo.x, jibunnohikoukinobakuhatunohonoo.y, jibunnohikoukinobakuhatunohonoo.graphichandle[(jibunnohikoukinobakuhatunohonoo.graphicnumber / 32) % 7], TRUE);
//👆🌞🌞🌞 🌞🌞🌞 🌞🌞 jibunnohikoukinobakuhatunohonoo.graphicnumberを32で割っているので32分の1のアニメーション速度です🌞🌞🌞 🌞🌞🌞 🌞🌞🌞
jibunnohikoukinobakuhatunohonoo.graphicnumber = jibunnohikoukinobakuhatunohonoo.graphicnumber + 1;
//👆🌞🌞🌞自分の飛行機の爆発の炎がアニメーションするよう設定が行われています
jibunnohikoukinobakuhatunohonoo.life = jibunnohikoukinobakuhatunohonoo.life - 1;
}
//👆 jibunnohikoukinobakuhatunohonoo.lifeに格納されている値が1以上なら自分の飛行機の爆発の炎の画像を描きます
//👆 jibunnohikoukinobakuhatunohonoo.lifeに格納されている値が0なら自分の飛行機の爆発の炎の画像が描かれることはありません
if ((key & PAD_INPUT_A) && (count == 0)) {
for (int i = 0; i < 2; i = i + 1) {
if (jibunnotama[i].life == 0) {
jibunnotama[i].x = jibunnohikouki.x + 35;
tsix = jibunnotama[i].x;
jibunnotama[i].y = jibunnohikouki.y + 10;
jibunnotama[i].life = 1;
break;
}
}
count = 10;
}
if (count > 0) { count = count - 1; }
for (int i = 0; i < 2; i = i + 1) {
if (jibunnotama[i].life == 1) {
//🌞🌞🌞 jibunnotama[i].lifeに1が代入されていると自分の弾がゲーム画面に表示されることになります jibunnotama[i].lifeに0が代入されていると自分の弾がゲーム画面に表示されることはありません
DrawGraph(jibunnotama[i].x, jibunnotama[i].y, jibunnotama[i].graphichandle[0], TRUE);
jibunnotama[i].x = jibunnotama[i].x + 10;
if (jibunnotama[i].x - tsix > 640)
//🌞🌞🌞発射された弾の位置のx座標が発射されたときの最初の弾の位置のx座標から640を超えて離れると条件式jibunnotama[i].x - tsix > 640は真の値1をとることになります
//🌞🌞🌞🌞🌞👆 tsixにはZボタンが押されたときの自分の弾のいる位置のx座標を記憶していたのでjibunnotama[i].xがZボタンが押されたときの自分の弾のいる位置から640ドット離れた時jibunnotama[i].x -tsix> 640は真の値1を持つことになります
jibunnotama[i].life = 0;
}
}
ScreenFlip();
ClearDrawScreen();
};
DxLib_End(); // DXライブラリの使用を終了します DXライブラリの使用しているメモリ領域が解放されます
return 0; // プログラムを終了します
}
デバッグなしで実行をしてから一度プログラムを終了し
生成されたexeファイルをハードディスクから探し出しクリックする方法により得られたプログラムの実行結果はこちらです
👇
https://www.youtube.com/watch?v=uk2wVDHWDgE
solarplexuss「わあ
可愛い
少しずつ敵の飛行機が動き出した」
新規登録で充実の読書を
- マイページ
- 読書の状況から作品を自動で分類して簡単に管理できる
- 小説の未読話数がひと目でわかり前回の続きから読める
- フォローしたユーザーの活動を追える
- 通知
- 小説の更新や作者の新作の情報を受け取れる
- 閲覧履歴
- 以前読んだ小説が一覧で見つけやすい
アカウントをお持ちの方はログイン
ビューワー設定
文字サイズ
背景色
フォント
組み方向
機能をオンにすると、画面の下部をタップする度に自動的にスクロールして読み進められます。
応援すると応援コメントも書けます