
スタートボタンを押すと一個のボールが現れ、
picture1の中を動き回り、壁に当たると跳ね返る、
スクリーンセイバーのようなプログラムを作って
いるのですが「ボールが壁に当たって跳ね返る」
部分がどうしても上手くいきません。この部分を
どなたか教えてください。お願いしますm(_ _)m
(見やすいように線を引きました。最後の方が「跳ね返りの部分です。それ以外の部分は、文の長さ制限にひっかかるため省いてあるところがあります。)
Private Sub Command1_Click()
x = Int(Rnd * 3900)
y = Int(Rnd * 3900)
r = 100
c = vbRed
Timer1.Enabled = True
Timer1.Interval = 200
Picture1.Circle (x, y), r, vbRed
End Sub
-----------------------------------------
Private Sub Timer1_Timer()
Picture1.FillColor = Picture1.BackColor
Picture1.Circle (x, y), r, Picture1.BackColor
dx = 100
dy = dx
x = x + dx
If x < 0 Then
x = 0 And dx = 0 - dx
If x > Picture1.Width Then
x = Picture1.Width And dx = 0 - dx
End If
End If
y = y + dy
If y < 0 Then
y = 0 And dy = 0 - dy
If y > Picture1.Height Then
y = Picture1.Height And dy = 0 - dy
End If
End If
Picture1.FillColor = vbRed
Picture1.Circle (x, y), r, vbRed
End Sub
No.3ベストアンサー
- 回答日時:
> 当たった瞬間、その場で右往左往してしまいます。
質問と、ソースが違うではないの!
であれば、こうでしょう。
> If x >= Picture1.Width OR x < = 0 Then
> s = -1
> Else
> s = 1
> End If
If x >= Picture1.Width OR x <= 0 Then
s = s * -1
End If
s と z は、グローバル変数にして、初期値を設定してね。
a-kumaさんのご助言のおかげで、無事プログラムが完成したした。本当に助かりました。またどうぞよろしくお願いしますm(_ _)m
No.4
- 回答日時:
ソースの表示が少なかった用です。
グローバル変数のところと、dx,dyの初期化を載せてませんでした。
m(_ _)m
Dim x%, y%, dx%, dy%
Dim r&, c&
Private Sub Command1_Click()
x = Int(Rnd * 3900)
y = Int(Rnd * 3900)
r = 100
c = vbRed
Timer1.Enabled = True
Timer1.Interval = 200
Picture1.Circle (x, y), r, vbRed
dx = 100
dy = dx
End Sub
'-----------------------------------------
Private Sub Timer1_Timer()
Picture1.FillColor = Picture1.BackColor
Picture1.Circle (x, y), r, Picture1.BackColor
x = x + dx
If x < 0 Then
x = 0
dx = 0 - dx
End If
If x > Picture1.Width Then
x = Picture1.Width
dx = 0 - dx
End If
y = y + dy
If y < 0 Then
y = 0
dy = 0 - dy
End If
If y > Picture1.Height Then
y = Picture1.Height
dy = 0 - dy
End If
Picture1.FillColor = vbRed
Picture1.Circle (x, y), r, vbRed
End Sub
No.2
- 回答日時:
Ifのところを見直してください。
If 条件式 Then
成立時の処理
Else
不成立時の処理
End if
xが0より小さいのにPicture1.Widthより大きいのはおかしいでしょ
とりあえずは、以下のように変更してください
If x < 0 Then
x = 0
dx = 0 - dx
End If
If x > Picture1.Width Then
x = Picture1.Width
dx = 0 - dx
End If
y = y + dy
If y < 0 Then
y = 0
dy = 0 - dy
End If
If y > Picture1.Height Then
y = Picture1.Height
dy = 0 - dy
End If
この回答への補足
ご指摘いただいたところは修正しましたが、ボールが壁に
当たった瞬間、その場で右往左往してしまいます。様々な方法を試してみたんですが、どうも上手くいきません。。
理由は、たぶん、壁に当たった時に進行方向が反転するも
のの、それがその後の動作に反映されていないからだと思
うのですが、どう直したらよいのか分かりません。
No.1
- 回答日時:
> If x < 0 Then
> x = 0 And dx = 0 - dx
> If x > Picture1.Width Then
> x = Picture1.Width And dx = 0 - dx
>
> End If
> End If
"And" の使い方が間違っています。英語のようには使えません。
If x < 0 Then
x = 0
dx = 0 - dx
ElseIf x > Picture1.Width Then
x = Picture1.Width
dx = 0 - dx
End If
y 方向も同様に直してね。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
【ExcelVBA】値を変更しながら...
-
複数のExcelファイルをマージす...
-
VBA Application.Matchについて...
-
VBAでCOPYを繰り返すと、処理が...
-
ワードの図形にマクロを登録で...
-
Vba セルの4辺について罫線が有...
-
vbsでのwebフォームへの入力制限?
-
【マクロ】並び替えの範囲が、...
-
エクセルの改行について
-
Vba Array関数について教えてく...
-
【マクロ】シートの変数へ入れ...
-
【マクロ】開いているブックの...
-
エクセルのマクロについて教え...
-
vb.net(vs2022)のtextboxのデザ...
-
【マクロ】売上一覧YYYYMMDDHHS...
-
VBAの「To」という語句について
-
ExcelのVBAコードについて教え...
-
Excelのマクロについて教えてく...
-
エクセルVBAのブックを開く方法...
-
Vba TextBox1.ControlSourceに...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VB6でマウスのドラッグで範囲を...
-
SavePictureで保存できない
-
RadioButtonについて
-
ピッ、ってアルファベットでど...
-
円の自転のさせ方
-
Matlabでsin波を使って矩形波を...
-
ボールが壁に当たって跳ね返る...
-
画像の90度回転表示の処理時間...
-
クリップボードにアクティブウ...
-
Picture box の サイズを変更
-
画像をランダムに表示させたい...
-
Matlab/SimulinkのChirp信号に...
-
if文で・・
-
ピクチャーボックスの画像を印...
-
SCALEの使い方教えてください
-
もぐらたたきのプログラミング
-
消す軌跡と残す軌跡
-
PictureBoxでのアニメーション...
-
(VB)ピクチャボックスに表示し...
-
数値が1の時は1で、他の数値は...
おすすめ情報