
コマンドボタンのEnabledプロパティーを変更したときの挙動が良くわからず
困っており、お教えいただけると幸いです。
Excelのワークシート上にCommandButtonを作り(名前をCommandButton1とします)、
module1に以下のプロシージャを書き、Enabledプロパティーを変化させます。
Sub test()
ActiveSheet.CommandButton1.Enabled = Not ActiveSheet.CommandButton1.Enabled
MsgBox "here"
End Sub
上記のプロシージャに期待したのは、Enabeldの状態が反転した後、
hereの文字が表示されると言うものですが、
実際は先にhereの文字が表示されてしまいます。
また、不思議なことにDoEventsを二つ連続でMsgBoxの前に入れると
きちんと動きます。
(ステップ実行でもきちんと動きます。)
最終的には、もっと長いプログラムの中で使う予定なので、
全てのEnabled文の後にDoEventsを二連続で書くという対症療法以外で、
良い解決方法が無いか、お教えいただけると幸いです。
なお、環境はwindowsXP、excel2003です。
よろしくお願いいたします。
No.1ベストアンサー
- 回答日時:
>良い解決方法が無いか、お教えいただけると幸いです。
VB6でもそうなんですが、VBAのコマンドボタン(いわゆるForms2.0)はこういう仕様になっています。
少し難しい話になってしまいますが
Enabledプロパティの状態が即座に反映されるようになるには、
コマンドボタンの再描画の結果を待つことが必要になります。
そしてこの現象は、再描画が完了する前にMsgBox(モーダルなフォーム)が出現してしまい、
再描画が待たされている状態なんですね。
(基本的にメッセージボックスが出てしまったら、その親は画面の再描画が出来なくなる)
で、VB6/VBAでは再描画を待つということがDoEventsでしか(ほぼ)出来ないのです。
>全てのEnabled文の後にDoEventsを二連続で書くという対症療法
ですので、これは対症療法ではありません。
もっとも、元々のコードが酷いからこのような結論になってしまうのですが(^^;
test()では、「アクティブシートのCommandButton1」の状態しか変えることが出来ませんよね。
アクティブシートにコマンドボタンが無ければ、
いや「CommnandButton1」というオブジェクトが無ければエラーになってしまいます。
このようなコードを私は書かないわけでは決してないんですが、
「全てのEnabled文の後に・・・」という愚痴は、絶対に言いません。だって、それは分かりきって書いていますから。
だったらこうするべきでしょう。
'MSForms.CommandButtonでエラーになる場合は"object"で
Sub ChangeStatus(oCmd As MSForms.CommandButton)
DoEvents
oCmd.Enabled = Not oCmd.Enabled
DoEvents
'MsgBox "here"
End Sub
Sub test()
call ChangeStatus(ActiveSheet.CommandButton1)
MsgBox "here"
End Sub
'--------------------------------
つまり、「コマンドボタンの状態を変え、Doeventsを発行する」という一連の作業を関数にしてしまえばいいんですよ。
ちなみにDoEventsは状態を変える前と後で発行してもうまく行きます。
ご回答、ありがとうございます。
自分でも散々調べたのですが、理由がわからず困っておりました。
しかし、piyo2000様の明快な回答を拝見させていただき、スッキリいたしました!
また、作業を関数にして解決する案、目から鱗が落ちた感じです。
こういう解決方法があったんですね。大変参考になりました。
本当にありがとうございました。
No.2
- 回答日時:
CommandButtonなどはUserFormで使うことが前提のためのように思います
ご質問と同様のことをUserForm上で実現すると
Enabledを変更した後にDoEventsを一度実行すればMsgBoxを表示する前に状態は変化するようです
Worksheet上の場合は2度の実行が必要なようですが …
ご回答ありがとうございます。
恥ずかしながらCommandButtonなどはUserFormで使うと言う前提も知らずに
使っておりました。
勉強になります。
しかし、worksheet上の場合は二回実行しないと動かないと言うのも、
面白いものですね。困ったときのDoEventsと言う感じですね。
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) エクセルのマクロについて教えてください。 7 2023/07/04 09:18
- Visual Basic(VBA) VBAにてメール作成した際、一部指定箇所のみ赤文字にしたいです。 下記の内容ですと作成されたメール本 1 2022/04/27 13:31
- Visual Basic(VBA) 3つのプロシージャをまとめたら実行時エラー発生で対応不能 6 2022/05/17 01:47
- Visual Basic(VBA) ファイル全てを .xlsm に変更したところ、プログラムが途中で落ちてしまっています 17 2022/12/07 12:03
- Visual Basic(VBA) vba メモリ節約 3 2022/09/16 21:45
- Visual Basic(VBA) 複数のcsvファイルをExcelに一括変換したい 2 2023/03/03 12:44
- Excel(エクセル) Excel VBAどこが間違ってますか? 4 2023/07/17 10:04
- Visual Basic(VBA) エクセルのマクロについて教えてください。 2 2023/07/10 09:06
- Visual Basic(VBA) 動かなくなってしまった古いVBAを動くようにしたい 8 2022/09/20 13:57
- Excel(エクセル) 2つのVBAを一緒にしたら機能しなくなりました(エクセル) 7 2022/06/02 12:41
このQ&Aを見た人はこんなQ&Aも見ています
-
性格悪い人が優勝
できるだけ性格悪い人になって回答をお願いします。
-
【お題】動物のキャッチフレーズ
【お題】「百獣の王 ライオン」「実は動物界最強 カバ」は分かるけど、それはちょっとピンと来ないなと思った動物のキャッチフレーズ
-
歩いた自慢大会
「めちゃくちゃ歩いたエピソード」を教えてください。
-
これ何て呼びますか Part2
あなたのお住いの地域で、これ、何て呼びますか?
-
カラオケの鉄板ソング
歌えばその場が絶対盛り上がる「鉄板ソング」を教えてください!
-
VBA シートのボタン名を変更したい
Visual Basic(VBA)
-
コマンドボタンのEnterイベント後に、フォーカスを移動したい。
その他(Microsoft Office)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・昔のあなたへのアドバイス
- ・字面がカッコいい英単語
- ・許せない心理テスト
- ・歩いた自慢大会
- ・「I love you」 をかっこよく翻訳してみてください
- ・ゆるやかでぃべーと タイムマシンを破壊すべきか。
- ・はじめての旅行はどこに行きましたか?
- ・準・究極の選択
- ・この人頭いいなと思ったエピソード
- ・「それ、メッセージ花火でわざわざ伝えること?」
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・【お題】甲子園での思い出の残し方
- ・【お題】動物のキャッチフレーズ
- ・人生で一番思い出に残ってる靴
- ・これ何て呼びますか Part2
- ・スタッフと宿泊客が全員斜め上を行くホテルのレビュー
- ・あなたが好きな本屋さんを教えてください
- ・かっこよく答えてください!!
- ・一回も披露したことのない豆知識
- ・ショボ短歌会
- ・いちばん失敗した人決定戦
- ・性格悪い人が優勝
- ・最速怪談選手権
- ・限定しりとり
- ・性格いい人が優勝
- ・これ何て呼びますか
- ・チョコミントアイス
- ・単二電池
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・ゴリラ向け動画サイト「ウホウホ動画」にありがちなこと
- ・泣きながら食べたご飯の思い出
- ・一番好きなみそ汁の具材は?
- ・人生で一番お金がなかったとき
- ・カラオケの鉄板ソング
- ・自分用のお土産
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ListBoxで改行したい
-
for文の実行速度を遅くしたいの...
-
PowerPoint の VBA
-
C#を用いて描画する四角形の角...
-
Excel VBA:コントロールボタン...
-
Visual C++ MaskedTextBoxの右...
-
DrawLineで引いた線が消えてし...
-
VB.NETでグラフィックを描くと...
-
C#で壁の当たり判定と自キャラ...
-
給紙トレイをダイアログを使わ...
-
Word 描画オブジェクトを削除...
-
WindowsAPIの、ウインドウの表...
-
ローソク足をPHPで描くには・・・
-
図の削除直後の再描画
-
円の頂点の求め方を知りたいです。
-
Word:描画オブジェクト内の画...
-
VBA シートのボタン名を変更し...
-
実行時エラー 438になった時の...
-
worksheetFunctionクラスのVloo...
-
ユーザーフォームを表示中にシ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ListBoxで改行したい
-
for文の実行速度を遅くしたいの...
-
C#を用いて描画する四角形の角...
-
PowerPoint の VBA
-
ビットマップに描画をしてピク...
-
win32api複数のタイマーを同時...
-
給紙トレイをダイアログを使わ...
-
.NETのPictureBoxでウインドウ...
-
VB.netで図形描画ができません^^;
-
delphi 画面のちらつき
-
C# DrawImage 物理サイズでな...
-
図の削除直後の再描画
-
VC++ MFCチェックボックスの色...
-
MFCでのコンボボックスについて
-
フォームに描画して表示をスク...
-
Word 描画オブジェクトを削除...
-
円の頂点の求め方を知りたいです。
-
DrawLineで引いた線が消えてし...
-
コンボボックスのテキストを消...
-
vb6のTEXTBOX
おすすめ情報