teratail header banner
teratail header banner
質問するログイン新規登録

質問編集履歴

4

編集

2020/06/23 07:10

投稿

KZK13
KZK13

スコア43

title CHANGED
File without changes
body CHANGED
@@ -9,4 +9,258 @@
9
9
  orを || に編集しました。
10
10
  [編集後のコード](https://pastebin.com/JNBsKX0M)
11
11
 
12
- [さらに編集後のコード](https://pastebin.com/u8EYitcS)
12
+ [さらに編集後のコード](https://pastebin.com/u8EYitcS)
13
+
14
+ fanaさんの意見を参考に作ったコードです。※未完成です。
15
+ ```
16
+ #include "DxLib.h"
17
+ #include <string>
18
+
19
+ int konnnitiwasound = 0;
20
+ int situreisimasitasound = 0;
21
+ char String[256];
22
+ char StringA[256];
23
+ int InputHandle;
24
+ int InputHandleA;
25
+ int modoru = 0;
26
+ std::string input;
27
+ std::string message;
28
+ std::string messageA;
29
+
30
+
31
+
32
+ int i;
33
+
34
+ int a[1] = { 3};
35
+
36
+ int suuti = 256;
37
+
38
+ int duration = 0;
39
+ int konnnitiwa = 0;
40
+ int sitaidou = 0;
41
+ int sitaidouA = 0;
42
+ int mozicount = 0;
43
+ int mozicount2 = 0;
44
+ int mozicount3 = 0;
45
+
46
+ int gimonnlock = 0;
47
+
48
+ // 自作文字列比較関数
49
+ int my_strcmp(const char* s1, const char* s2) {
50
+ // 先頭から走査して差があればループ終了
51
+ for (; *s1 == *s2; s1++, s2++) {
52
+ // 終了前に終端文字が見つかったら差分なし
53
+ if (*s1 == '\0'&& *s2 == '\0') { return 0; }
54
+ } return *s1 > * s2 ? 1 : -1;
55
+ }
56
+
57
+ int my_str2(const char* s1, const char* s2)//ここで入力した文字列と用意された文字列を引数として扱う。
58
+
59
+ {
60
+ //s1, s2を比較する関数を使うためだけにs2の文字列のサイズが必要なので、変数aに用意した文字列の情報s2を文字列の長さを測るための関数strlenに引数として渡す。
61
+ const size_t a = strlen(s2);
62
+ //無限ループする。
63
+ for (;;) {
64
+ //関数memcmpの返り値が0の時は一致した時なので、==0とする。
65
+ if (memcmp(s1, s2, a) == 0)
66
+
67
+ return 1;//入力した文字列にい指定された文字列が入っていた場合は1を返すように設定した。
68
+ //入力した文字列が最後の文字まで到達した場合は一致する文字列がないということなので0を返すようにした。
69
+ else if (*s1 == '\0')
70
+
71
+ return 0;//入っていなかった
72
+ //文字列が一致した場合でも一致する文字列がない場合でも入力した文字列の一文字分の文字コードのバイト数?が繰り上がるようにした。
73
+ else
74
+
75
+ ++s1;
76
+
77
+ }
78
+
79
+ }
80
+
81
+ int rireki = 0;
82
+ int rireki2 = 0;
83
+ int LEFTmark = 0;
84
+ const char* str[100] = {
85
+ "どんな映画が好きなんですか?","はい!大好きです!!あなたはどんな映画が好きですか? " ,"私は恋愛映画が好きです!",
86
+ "人間観察が好きだからかもしれません。","申し訳ありません。わかりません。" ,"おはようございます。今日は何をなさるんですか?"};//ここで文字を直接書いてるので、この文字のバイト数が各posmozi[]に入るだけ
87
+ int frame[100] = { 10,10 ,10,10,10,10};//次の一文字が出るまでのカウンタとして働いている、ここの数値を変えることで文字が一文字ずつ出るまでの間隔を設定できる。
88
+ int posmozi[100];//文字のバイト数が入る箱を表している。
89
+ int countS[100];//次の文字が出るまでのカウントするためのもの
90
+ int z;//関数drawString外でも使えるように外にも定義を書いた。zの数値は関係なく、文字列が入った数列がif文により同じ変数zの時にframe[z]と同じになるまで+1されていったり、+2バイトor+1バイトされていくため、
91
+ //文字が一文字ずつ入っていく、なんでzの変数に値を入れて動かす必要がないのだ。ちなみにfor (z = 0; z < 3; ++z)で書いてしまうとキーAを押した際のif文に関係なく関数drawStringの最初のzどこかに値が入っただけで繰り返しを開始してしまうため、今回のように同じ変数zの時にフレームを利用して描画するようにした。
92
+ char c = str[z][posmozi[z]];//関数drawString外でも使えるように外にも定義を書いた。
93
+
94
+
95
+ void drawString(int z, int x, int y, int color)
96
+ {
97
+ c = str[z][posmozi[z]];//posmozi[z]
98
+ if (countS[z] == 0 && c != '\0')
99
+ posmozi[z] += IsDBCSLeadByte(c) ? 2 : 1;
100
+ if (++countS[z] == frame[z]) countS[z] = 0;
101
+ DrawFormatString(x, y, color, "%.*s", posmozi[z], str[z]);
102
+ DrawFormatString(300, 300, (0, 0, 255), "countS[0]は%d", countS[0]);
103
+ }
104
+
105
+
106
+ int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow)
107
+ {
108
+
109
+
110
+ SetGraphMode(1500, 780, 32); // ウィンドウの大きさを指定
111
+ ChangeWindowMode(TRUE); // 全画面ではなくウインドウを使用
112
+ // DXライブラリの初期化
113
+ if (DxLib_Init() == -1) return -1;
114
+ SetFontSize(42); //サイズを42に変更
115
+ // 描画先を裏にする
116
+ SetDrawScreen(DX_SCREEN_BACK);
117
+
118
+ // キー入力ハンドルを作る(キャンセルなし全角文字有り数値入力じゃなし)
119
+ //MakeKeyInputは開発者の方が一回呼び出せば使えるように作ったのでループ内には書かない。
120
+ InputHandle = MakeKeyInput(50, FALSE, FALSE, FALSE);
121
+
122
+ // 作成したキー入力ハンドルをアクティブにする
123
+ SetActiveKeyInput(InputHandle);
124
+
125
+ // キー入力終了待ちループ
126
+ // (ProcessMessageをループごとに行う)
127
+
128
+ while (ProcessMessage() == 0)
129
+ {
130
+
131
+ // 画面の初期化
132
+ ClearDrawScreen();
133
+
134
+
135
+ //まずは描画する部分から作る。
136
+ // 入力モードを描画
137
+ DrawKeyInputModeString(640, 480);
138
+ // 入力途中の文字列を描画
139
+ DrawKeyInputString(0, 0, InputHandle);//InputHandleはint型とリファレンスに書いてあったんで
140
+
141
+
142
+ //その後にif文での分岐を考える。
143
+ // 入力が終了している場合は終了
144
+ //ループ内とは言えエンターキー一回でCheckKeyInputが呼べればいい。
145
+ //エンターキーが押されていないとき?の部分。
146
+ if (CheckKeyInput(InputHandle) != 0) {
147
+
148
+ // 入力された文字列を取得
149
+
150
+ char buffer[256];//★InputHandleに入ったのは文字のデータなので、文字のデータが受け取れる変数の型にする。
151
+
152
+ // 入力された文字列を取得、その文字列を数値に変換
153
+ GetKeyInputString(buffer, InputHandle);//ここでInputHandleに入力された文字列の数値をGetKeyInputStringにより文字コードに変換したものを上でchar型で定義したbufferに入れる。
154
+ input = buffer;//bufferに入った文字コードに変換したものを
155
+
156
+
157
+ DrawString(0, 0, input.c_str(), GetColor(255, 255, 255));
158
+
159
+
160
+
161
+
162
+ /* 配列の要素を出力 */
163
+
164
+ //inputに入った文字のデータを数値化するために input.c_str()を定義して、下のif文に使った。
165
+
166
+ //変数inputに入る前はchar型のbufferに文字列が入るので、my_str2はchar*型を引数にとるため、char*型は文字列を定義するので、
167
+ //関数my_str2にはそのまま文字列が使えるので、その文字列が入っているbufferを直接書いた。
168
+
169
+
170
+ if (my_str2(buffer, "映画") && my_str2(buffer, "好き")) {
171
+ // message = "どんな映画が好きなんですか?";
172
+ konnnitiwasound = LoadSoundMem("line-girl1-konnichiha1.mp3");
173
+ PlaySoundMem(konnnitiwasound, DX_PLAYTYPE_BACK);
174
+ z = 0;
175
+ ++mozicount;
176
+ if (my_str2(buffer, "どんな") && my_str2(buffer, "?") ||
177
+ my_str2(buffer, "?")) {
178
+ // message = "どんな映画が好きなんですか?";
179
+ konnnitiwasound = LoadSoundMem("line-girl1-konnichiha1.mp3");
180
+ PlaySoundMem(konnnitiwasound, DX_PLAYTYPE_BACK);
181
+ z = 1;
182
+ ++mozicount;
183
+ gimonnlock = 1;
184
+ }
185
+ else if (my_str2(buffer, "なぜ") && my_str2(buffer, "?") ||
186
+ my_str2(buffer, "なんで") && my_str2(buffer, "?")) {
187
+ // message = "どんな映画が好きなんですか?";
188
+ konnnitiwasound = LoadSoundMem("line-girl1-konnichiha1.mp3");
189
+ PlaySoundMem(konnnitiwasound, DX_PLAYTYPE_BACK);
190
+ z = 3;
191
+ ++mozicount;
192
+ }
193
+ }
194
+
195
+
196
+ if (my_str2(buffer, "映画") && my_str2(buffer, "事実") || my_str2(buffer, "映画") && my_str2(buffer, "アクション")) {
197
+ // message = "どんな映画が好きなんですか?";
198
+ // konnnitiwasound = LoadSoundMem("line-girl1-konnichiha1.mp3");
199
+ //PlaySoundMem(konnnitiwasound, DX_PLAYTYPE_BACK);
200
+ z = 2;
201
+ ++mozicount;
202
+ }
203
+
204
+ if (my_str2(buffer, "おはよう") ) {
205
+ // message = "どんな映画が好きなんですか?";
206
+ konnnitiwasound = LoadSoundMem("line-girl1-konnichiha1.mp3");
207
+ PlaySoundMem(konnnitiwasound, DX_PLAYTYPE_BACK);
208
+ z = 5;
209
+ ++mozicount;
210
+ }
211
+ else {
212
+ z = 4;
213
+ ++mozicount;
214
+ }
215
+
216
+
217
+ //duration = 1;
218
+ // 再度インプットハンドルをアクティブにする
219
+ SetActiveKeyInput(InputHandle);
220
+ // 入力文字列を初期化する
221
+ SetKeyInputString("", InputHandle);
222
+
223
+ }
224
+
225
+ // DrawFormatString(100, 150, GetColor(255, 255, 0), "ProcessMessage()は%d,modoruは%d", ProcessMessage(), modoru);
226
+ DrawFormatString(0, 150, GetColor(255, 255, 0), "zは%d,konnnitiwaは%d,sitaidouは%d,mozicountは%d", z, konnnitiwa, sitaidou, mozicount);
227
+ DrawFormatString(0, 250, GetColor(255, 255, 0), "mozicount2は%d,input.c_str()は%d, LEFTmarkは%d", mozicount2, input.c_str(), LEFTmark);
228
+
229
+ //新しい言葉の処理
230
+
231
+ //文字カウントが1の時
232
+ if (mozicount > 0 ) {
233
+ drawString(z, 10, 100, GetColor(5, 255, 255));
234
+
235
+ }
236
+
237
+
238
+ // 裏画面の内容を表画面に反映させる
239
+ ScreenFlip();
240
+
241
+
242
+
243
+
244
+
245
+ }
246
+
247
+ // 用済みのインプットハンドルを削除する
248
+ DeleteKeyInput(InputHandle);
249
+
250
+ // 画面の初期化
251
+ ClearDrawScreen();
252
+
253
+ // 裏画面の内容を表画面に反映させる
254
+ ScreenFlip();
255
+
256
+ // キー入力待ち
257
+ // WaitKey();
258
+
259
+ //ループないやループから出た後で何かしらの問題が発生したら終了する。
260
+ // DXライブラリの使用終了
261
+ DxLib_End();
262
+
263
+ // 終了
264
+ return 0;
265
+ }
266
+ ```

3

hennsyuu

2020/06/23 07:10

投稿

KZK13
KZK13

スコア43

title CHANGED
File without changes
body CHANGED
@@ -9,4 +9,4 @@
9
9
  orを || に編集しました。
10
10
  [編集後のコード](https://pastebin.com/JNBsKX0M)
11
11
 
12
- [さらに編集後](https://pastebin.com/u8EYitcS)
12
+ [さらに編集後のコード](https://pastebin.com/u8EYitcS)

2

編集

2020/06/23 03:27

投稿

KZK13
KZK13

スコア43

title CHANGED
File without changes
body CHANGED
@@ -7,4 +7,6 @@
7
7
  if (my_str2(buffer, "なぜ") && my_str2(buffer, "映画") && my_str2(buffer, "好き") && my_str2(buffer, "?") or
8
8
  my_str2(buffer, "なんで") && my_str2(buffer, "映画")&& my_str2(buffer, "好き") && my_str2(buffer, "?"))の映画と好きという言葉が被ってしまうためバグが起きたり、mozicountが一気に+2されたりしてしまします。何か良い解決方法はないでしょうか。
9
9
  orを || に編集しました。
10
- [編集後のコード](https://pastebin.com/JNBsKX0M)
10
+ [編集後のコード](https://pastebin.com/JNBsKX0M)
11
+
12
+ [さらに編集後](https://pastebin.com/u8EYitcS)

1

編集

2020/06/23 03:26

投稿

KZK13
KZK13

スコア43

title CHANGED
File without changes
body CHANGED
@@ -6,249 +6,5 @@
6
6
  例えばif (my_str2(buffer, "映画") && my_str2(buffer, "好き")) と
7
7
  if (my_str2(buffer, "なぜ") && my_str2(buffer, "映画") && my_str2(buffer, "好き") && my_str2(buffer, "?") or
8
8
  my_str2(buffer, "なんで") && my_str2(buffer, "映画")&& my_str2(buffer, "好き") && my_str2(buffer, "?"))の映画と好きという言葉が被ってしまうためバグが起きたり、mozicountが一気に+2されたりしてしまします。何か良い解決方法はないでしょうか。
9
-
10
- ```
11
- #include "DxLib.h"
12
- #include <string>
13
-
14
- int konnnitiwasound = 0;
15
- int situreisimasitasound = 0;
16
- char String[256];
17
- char StringA[256];
18
- int InputHandle;
19
- int InputHandleA;
20
- int modoru = 0;
9
+ orを || に編集しました。
21
- std::string input;
22
- std::string message;
23
- std::string messageA;
24
-
25
-
26
-
27
- int i;
28
-
29
- int a[1] = {3};
30
-
31
- int suuti = 256;
32
-
33
- int duration = 0;
34
- int konnnitiwa = 0;
35
- int sitaidou = 0;
36
- int sitaidouA = 0;
37
- int mozicount = 0;
38
- int mozicount2 = 0;
39
- int mozicount3 = 0;
40
-
41
- // 自作文字列比較関数
42
- int my_strcmp(const char* s1, const char* s2) {
43
- // 先頭から走査して差があればループ終了
44
- for (; *s1 == *s2; s1++, s2++) {
45
- // 終了前に終端文字が見つかったら差分なし
46
- if (*s1 == '\0'&& *s2 == '\0') { return 0; }
47
- } return *s1 > * s2 ? 1 : -1;
48
- }
49
-
50
- int my_str2(const char* s1, const char* s2)//ここで入力した文字列と用意された文字列を引数として扱う。
51
-
52
- {
53
- //s1, s2を比較する関数を使うためだけにs2の文字列のサイズが必要なので、変数aに用意した文字列の情報s2を文字列の長さを測るための関数strlenに引数として渡す。
54
- const size_t a = strlen(s2);
55
- //無限ループする。
56
- for (;;) {
57
- //関数memcmpの返り値が0の時は一致した時なので、==0とする。
58
- if (memcmp(s1, s2, a) == 0)
59
-
60
- return 1;//入力した文字列にい指定された文字列が入っていた場合は1を返すように設定した。
61
- //入力した文字列が最後の文字まで到達した場合は一致する文字列がないということなので0を返すようにした。
62
- else if (*s1 == '\0')
63
-
64
- return 0;//入っていなかった
65
- //文字列が一致した場合でも一致する文字列がない場合でも入力した文字列の一文字分の文字コードのバイト数?が繰り上がるようにした。
66
- else
67
-
68
- ++s1;
69
-
70
- }
71
-
72
- }
73
-
74
- int rireki = 0;
75
- int rireki2 = 0;
76
- int LEFTmark = 0;
77
- const char* str[100] = {
78
- "どんな映画が好きなんですか?","はい!大好きです!!あなたはどんな映画が好きですか? " ,"私は恋愛映画が好きです!",
79
- "人間観察が好きだからかもしれません。","申し訳ありません。わかりません。" ,"おはようございます。今日は何をなさるんですか?"};//ここで文字を直接書いてるので、この文字のバイト数が各posmozi[]に入るだけ
80
- int frame[100] = { 10,10 ,10,10,10,10};//次の一文字が出るまでのカウンタとして働いている、ここの数値を変えることで文字が一文字ずつ出るまでの間隔を設定できる。
81
- int posmozi[100];//文字のバイト数が入る箱を表している。
82
- int countS[100];//次の文字が出るまでのカウントするためのもの
83
- int z;//関数drawString外でも使えるように外にも定義を書いた。zの数値は関係なく、文字列が入った数列がif文により同じ変数zの時にframe[z]と同じになるまで+1されていったり、+2バイトor+1バイトされていくため、
84
- //文字が一文字ずつ入っていく、なんでzの変数に値を入れて動かす必要がないのだ。ちなみにfor (z = 0; z < 3; ++z)で書いてしまうとキーAを押した際のif文に関係なく関数drawStringの最初のzどこかに値が入っただけで繰り返しを開始してしまうため、今回のように同じ変数zの時にフレームを利用して描画するようにした。
85
- char c = str[z][posmozi[z]];//関数drawString外でも使えるように外にも定義を書いた。
86
-
87
-
88
- void drawString(int z, int x, int y, int color)
89
- {
90
- c = str[z][posmozi[z]];//posmozi[z]
91
- if (countS[z] == 0 && c != '\0')
92
- posmozi[z] += IsDBCSLeadByte(c) ? 2 : 1;
93
- if (++countS[z] == frame[z]) countS[z] = 0;
94
- DrawFormatString(x, y, color, "%.*s", posmozi[z], str[z]);
95
- DrawFormatString(300, 300, (0, 0, 255), "countS[0]は%d", countS[0]);
96
- }
97
-
98
-
99
- int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow)
100
- {
101
-
102
-
103
- SetGraphMode(1500, 780, 32); // ウィンドウの大きさを指定
104
- ChangeWindowMode(TRUE); // 全画面ではなくウインドウを使用
105
- // DXライブラリの初期化
106
- if (DxLib_Init() == -1) return -1;
107
- SetFontSize(42); //サイズを42に変更
108
- // 描画先を裏にする
109
- SetDrawScreen(DX_SCREEN_BACK);
110
-
111
- // キー入力ハンドルを作る(キャンセルなし全角文字有り数値入力じゃなし)
112
- //MakeKeyInputは開発者の方が一回呼び出せば使えるように作ったのでループ内には書かない。
113
- InputHandle = MakeKeyInput(50, FALSE, FALSE, FALSE);
114
-
115
- // 作成したキー入力ハンドルをアクティブにする
116
- SetActiveKeyInput(InputHandle);
117
-
118
- // キー入力終了待ちループ
119
- // (ProcessMessageをループごとに行う)
120
-
121
- while (ProcessMessage() == 0)
122
- {
123
-
124
- // 画面の初期化
125
- ClearDrawScreen();
126
-
127
-
128
- //まずは描画する部分から作る。
129
- // 入力モードを描画
130
- DrawKeyInputModeString(640, 480);
131
- // 入力途中の文字列を描画
132
- DrawKeyInputString(0, 0, InputHandle);//InputHandleはint型とリファレンスに書いてあったんで
133
-
134
-
135
- //その後にif文での分岐を考える。
136
- // 入力が終了している場合は終了
137
- //ループ内とは言えエンターキー一回でCheckKeyInputが呼べればいい。
138
- //エンターキーが押されていないとき?の部分。
139
- if (CheckKeyInput(InputHandle) != 0) {
140
-
141
- // 入力された文字列を取得
142
-
143
- char buffer[256];//★InputHandleに入ったのは文字のデータなので、文字のデータが受け取れる変数の型にする。
144
-
145
- // 入力された文字列を取得、その文字列を数値に変換
146
- GetKeyInputString(buffer, InputHandle);//ここでInputHandleに入力された文字列の数値をGetKeyInputStringにより文字コードに変換したものを上でchar型で定義したbufferに入れる。
147
- input = buffer;//bufferに入った文字コードに変換したものを
10
+ [編集後のコード](https://pastebin.com/JNBsKX0M)
148
-
149
-
150
- DrawString(0, 0, input.c_str(), GetColor(255, 255, 255));
151
-
152
-
153
-
154
-
155
- /* 配列の要素を出力 */
156
-
157
- //inputに入った文字のデータを数値化するために input.c_str()を定義して、下のif文に使った。
158
-
159
- //変数inputに入る前はchar型のbufferに文字列が入るので、my_str2はchar*型を引数にとるため、char*型は文字列を定義するので、
160
- //関数my_str2にはそのまま文字列が使えるので、その文字列が入っているbufferを直接書いた。
161
- if (my_str2(buffer, "映画") && my_str2(buffer, "好き")) {
162
- // message = "どんな映画が好きなんですか?";
163
- konnnitiwasound = LoadSoundMem("line-girl1-konnichiha1.mp3");
164
- PlaySoundMem(konnnitiwasound, DX_PLAYTYPE_BACK);
165
- z = 0;
166
- ++mozicount;
167
-
168
- }
169
- if (my_str2(buffer, "映画") && my_str2(buffer, "好き")&& my_str2(buffer, "?")) {
170
- // message = "どんな映画が好きなんですか?";
171
- konnnitiwasound = LoadSoundMem("line-girl1-konnichiha1.mp3");
172
- PlaySoundMem(konnnitiwasound, DX_PLAYTYPE_BACK);
173
- z = 1;
174
- ++mozicount;
175
-
176
- }
177
- if (my_str2(buffer, "映画") && my_str2(buffer, "事実") or my_str2(buffer, "映画") && my_str2(buffer, "アクション")) {
178
- // message = "どんな映画が好きなんですか?";
179
- // konnnitiwasound = LoadSoundMem("line-girl1-konnichiha1.mp3");
180
- //PlaySoundMem(konnnitiwasound, DX_PLAYTYPE_BACK);
181
- z = 2;
182
- ++mozicount;
183
- }
184
- if (my_str2(buffer, "なぜ") && my_str2(buffer, "映画") && my_str2(buffer, "好き") && my_str2(buffer, "?") or
185
- my_str2(buffer, "なんで") && my_str2(buffer, "映画")&& my_str2(buffer, "好き") && my_str2(buffer, "?")) {
186
- // message = "どんな映画が好きなんですか?";
187
- konnnitiwasound = LoadSoundMem("line-girl1-konnichiha1.mp3");
188
- PlaySoundMem(konnnitiwasound, DX_PLAYTYPE_BACK);
189
- z = 3;
190
- ++mozicount;
191
- }
192
- if (my_str2(buffer, "おはよう") ) {
193
- // message = "どんな映画が好きなんですか?";
194
- konnnitiwasound = LoadSoundMem("line-girl1-konnichiha1.mp3");
195
- PlaySoundMem(konnnitiwasound, DX_PLAYTYPE_BACK);
196
- z = 5;
197
- ++mozicount;
198
- }
199
- else {
200
- z = 4;
201
- ++mozicount;
202
- }
203
-
204
-
205
- //duration = 1;
206
- // 再度インプットハンドルをアクティブにする
207
- SetActiveKeyInput(InputHandle);
208
- // 入力文字列を初期化する
209
- SetKeyInputString("", InputHandle);
210
-
211
- }
212
-
213
- // DrawFormatString(100, 150, GetColor(255, 255, 0), "ProcessMessage()は%d,modoruは%d", ProcessMessage(), modoru);
214
- DrawFormatString(0, 150, GetColor(255, 255, 0), "zは%d,konnnitiwaは%d,sitaidouは%d,mozicountは%d", z, konnnitiwa, sitaidou, mozicount);
215
- DrawFormatString(0, 250, GetColor(255, 255, 0), "mozicount2は%d,input.c_str()は%d, LEFTmarkは%d", mozicount2, input.c_str(), LEFTmark);
216
-
217
- //新しい言葉の処理
218
-
219
- //文字カウントが1の時
220
- if (mozicount > 0 ) {
221
- drawString(z, 10, 100, GetColor(5, 255, 255));
222
-
223
- }
224
-
225
-
226
- // 裏画面の内容を表画面に反映させる
227
- ScreenFlip();
228
-
229
-
230
-
231
-
232
-
233
- }
234
-
235
- // 用済みのインプットハンドルを削除する
236
- DeleteKeyInput(InputHandle);
237
-
238
- // 画面の初期化
239
- ClearDrawScreen();
240
-
241
- // 裏画面の内容を表画面に反映させる
242
- ScreenFlip();
243
-
244
- // キー入力待ち
245
- // WaitKey();
246
-
247
- //ループないやループから出た後で何かしらの問題が発生したら終了する。
248
- // DXライブラリの使用終了
249
- DxLib_End();
250
-
251
- // 終了
252
- return 0;
253
- }
254
- ```