
No.4ベストアンサー
- 回答日時:
ストップボタンはないけれど、こんなの作ってみました。
まっさらなワークシートで試してみてください。
Sub ルーレット()
Range("B3:K9").Select
With Selection
.Font.Name = "Arial Black"
.Font.Size = 20
.HorizontalAlignment = xlCenter
.VerticalAlignment = xlCenter
With .Borders
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
.HorizontalAlignment = xlCenter
.VerticalAlignment = xlBottom
End With
ActiveWorkbook.Names.Add Name:="table", RefersTo:=Selection
n = 0
For Each c In Range("table")
n = n + 1
c.Value = n
Next
For i = 1 To 2
For Each c In Range("table")
c.Select
For m = 20 To 3 Step -1
Selection.Interior.ColorIndex = m
Next m
Range("table").Interior.ColorIndex = 0
Next c
Next i
Randomize
x = Int(Rnd * 70) + 1
For Each c In Range("table")
c.Select
For m = 20 To 3 Step -1
Selection.Interior.ColorIndex = m
Next m
Range("table").Interior.ColorIndex = 0
If c.Value = x Then
Selection.Interior.ColorIndex = 3
Exit Sub
End If
Next c
End Sub
No.7
- 回答日時:
ワークシートSheet1にオートシェイプの中から太い矢印を貼り付けました。
「オートシェイプ 2」という名前でした。
もうひとつ、コマンドボタンを貼り付けました。
Sheet1のコマンドボタンのクリックイベントに
Private Sub CommandButton1_Click()
Worksheets("sheet1").Range("a1").Activate
For i = 2 To 10
t0 = Timer
Do While Timer < t0 + 1
DoEvents
'ActiveSheet.Cells(i - 1, "A") = ""
'Cells(i, "A") = "A"
Worksheets("sheet1").Shapes("オートシェイプ 2").Left = i * 50
Loop
Next i
End Sub
を貼り付けます。
ボタンをクリックするとかくかくと10秒間、矢印が動いていきます。
スムーズにするには1秒をもっと短くする。
太い矢印を、イメージのピクチャなどに変える。
とめるのはとめるフラグを聞いていて、ONならシェイプをDeleteする。コンなのはどうでしょう。やはり道具立ての力不足ですね。
オフィス系などでなく・エクセルVBA以外のプログラム言語に目を向けられることを。
No.6
- 回答日時:
No5です。
こっちのほうがいいかもSub ルーレット開始()
Cells(1, 1) = ""
Range("B3:K9").Select
With Selection
.Font.Name = "Arial Black"
.Font.Size = 20
.HorizontalAlignment = xlCenter
.VerticalAlignment = xlCenter
With .Borders
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
.HorizontalAlignment = xlCenter
.VerticalAlignment = xlBottom
End With
ActiveWorkbook.Names.Add Name:="table", RefersTo:=Selection
Range("table").Interior.ColorIndex = 0
n = 0
For Each c In Range("table")
n = n + 1
c.Value = n
Next
Do
For Each c In Range("table")
c.Select
If Cells(1, 1) = "stop" Then
Selection.Interior.ColorIndex = 3
Exit Sub
End If
DoEvents
Next c
Loop
End Sub
Sub ルーレットSTOP()
Cells(1, 1) = "stop"
End Sub
No.5
- 回答日時:
No4さんのをそのまま拝借してストップボタンを付けてみました。
Sub ルーレットSTART()
Cells(1, 1) = ""
Range("B3:K9").Select
With Selection
.Font.Name = "Arial Black"
.Font.Size = 20
.HorizontalAlignment = xlCenter
.VerticalAlignment = xlCenter
With .Borders
.LineStyle = xlContinuous
.Weight = xlThin
.ColorIndex = xlAutomatic
End With
.HorizontalAlignment = xlCenter
.VerticalAlignment = xlBottom
End With
ActiveWorkbook.Names.Add Name:="table", RefersTo:=Selection
n = 0
For Each c In Range("table")
n = n + 1
c.Value = n
Next
Do While Cells(1, 1) = ""
For Each c In Range("table")
c.Select
If Cells(1, 1) = "stop" Then
Selection.Interior.ColorIndex = 3
Exit Sub
End If
DoEvents
Range("table").Interior.ColorIndex = 0
Next c
Loop
End Sub
Sub ルーレットSTOP()
Cells(1, 1) = "stop"
End Sub
No.3
- 回答日時:
再びこんにちは。
VBAからワークシートをいじる場合、VBで言うところのタイマーコントロールが使えません。
従って、スタートボタンを押したらループでグルグル回し、その間にストップボタンも受け付け、ストップされたらループから抜けるという処理になるはず。
答えを言えば、ループの中で DoEvents を発行してやれば済むと思います。
しかしスピードの調整等、結構シビアかもしれませんね。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
tableのcellpadding="0" cellsp...
-
TABLEのセルの中の文字を行単位...
-
画面幅に合わせてテーブルのカ...
-
テーブル内のセル間にスペース...
-
<th>タグを使っても太字にしな...
-
table表を横に並べる際の間隔指定
-
同じ幅指定のつもりなのに、ブ...
-
検索窓の位置を指定する方法
-
cssで、表示されるテキストによ...
-
テーブルタグの中にdivを含めて...
-
CSSで文字を一番下の中央に表示...
-
テーブル内でdlタグ使った際の...
-
テーブルの横に画像を
-
vbscriptで時計を作りたい
-
tableの要素(tr、td)に一...
-
テーブルのレイアウトがおかし...
-
スタイルシートで、画像の横に...
-
tableでcolspanを使うと次行以...
-
スタイルシートで colspan=3と...
-
オンマウスで異なるセルなどの...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
CSSで特定のテーブルだけに...
-
テーブルとテーブルの間隔について
-
テーブル内のセル間にスペース...
-
<th>タグを使っても太字にしな...
-
HTML tableのセルにtextareaを...
-
textareaの外側の文字が下付き...
-
TABLEのセルの中の文字を行単位...
-
HTML5で、テーブル内tdタグの高...
-
同じ幅指定のつもりなのに、ブ...
-
画面幅に合わせてテーブルのカ...
-
ホームページのテキストを折り...
-
テーブルデータを折り返して表...
-
table表を横に並べる際の間隔指定
-
テーブル幅が固定できない
-
データが表示されません
-
HTMLのテーブルをExcelにCopy&P...
-
テーブルタグについて
-
素朴なcaptionについて質問させ...
-
プロのWEB系のコーダーは左揃え...
-
テーブルがうまくいきません。
おすすめ情報