質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Q&A

解決済

1回答

7126閲覧

ExcelVBAで、チェックボックスを使用禁止にしたい

退会済みユーザー

退会済みユーザー

総合スコア0

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

0グッド

0クリップ

投稿2020/03/24 08:19

いつもお世話になっております。
ExcelVBAでチェックボックスを使うVBAを作っているのですが、分からないところがあります。

###実現したいこと
![イメージ説明

上画像のチェックボックスで、「対象ファイル全て」をチェックすると
それ以降のチェックボックスが使用禁止になるようにしたい

###聞きたいこと
考えたソースはこちらです。

VBA

1Option Explicit 2Sub Chk_ALL_Click() 3 If ActiveSheet.CheckBoxes("Chk_ALL").Value = xlOn Then 4 ActiveSheet.CheckBoxes("Chk_Excel").Enabled = False 5 ActiveSheet.CheckBoxes("Chk_Word").Enabled = False 6 ActiveSheet.CheckBoxes("Chk_PPT").Enabled = False 7 ActiveSheet.CheckBoxes("Chk_Msg").Enabled = False 8 Else 9 ActiveSheet.CheckBoxes("Chk_Excel").Enabled = True 10 ActiveSheet.CheckBoxes("Chk_Word").Enabled = True 11 ActiveSheet.CheckBoxes("Chk_PPT").Enabled = True 12 ActiveSheet.CheckBoxes("Chk_Msg").Enabled = True 13 End If 14End Sub

こちらにすると、画面はこうなります。
![イメージ説明

上記コードにしてチェックを入れると、Excel以降のチェックボックスはチェックを入れることができなくなります。
しかし、チェックを入れることはでいないとはいえ全体としてはそのまま見えている状態なので、
これを**「チェックを入れることが出来ない状態」と見て分かるようにしたい**です。

イメージ説明

↑こんな感じにしたいです。

それで色々と調べたところ、「Visible」も入れるといいということを知りました。
それで以下のようにコードを入れてみました。

VBA

1Option Explicit 2Sub Chk_ALL_Click() 3 If ActiveSheet.CheckBoxes("Chk_ALL").Value = xlOn Then 4 ActiveSheet.CheckBoxes("Chk_Excel").Visible = False 5 ActiveSheet.CheckBoxes("Chk_Word").Visible = False 6 ActiveSheet.CheckBoxes("Chk_PPT").Visible = False 7 ActiveSheet.CheckBoxes("Chk_Msg").Visible = False 8 Else 9 ActiveSheet.CheckBoxes("Chk_Excel").Visible = True 10 ActiveSheet.CheckBoxes("Chk_Word").Visible = True 11 ActiveSheet.CheckBoxes("Chk_PPT").Visible = True 12 ActiveSheet.CheckBoxes("Chk_Msg").Visible = True 13 End If 14End Sub 15

しかし、結果はこうなりました。

イメージ説明

そうではなく、上の画像のように灰色にして「チェックを入れることができない」ということが
見て分かるようにしたいのですが、どうすればよいのでしょうか?

他にも色々と調べたところ、文字のフォントカラーを変えるなど色々とあったのですが
フォントカラーを変えなくてもできるのでは・・と思ったので、ここで聞いてみました。
よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

フォームコントロールとアクティブXコントロールと2種類チェックボックスがありますが、
どちらの話でしょうか?

イメージ説明


追記

フォームコントロールの場合。
標準モジュールに、

ExcelVBA

1Sub test_chk5() 2 Dim j As Long 3 4 If Worksheets("Sheet1").CheckBoxes("Check Box 5").Value = xlOn Then 5 j = xlMixed 6 Else 7 j = xlOff 8 End If 9 Worksheets("Sheet1").CheckBoxes( _ 10 Array("Check Box 6", "Check Box 7", "Check Box 8")).Value = j 11End Sub

と記入して、チェックボックスにマクロの登録をする。

ActiveXコントロールの場合、
当該シートのモジュールに、

ExcelVBA

1Private Sub CheckBox1_Click() 2 With Me.CheckBox1 3 Me.CheckBox2.Enabled = Not .Value 4 Me.CheckBox3.Enabled = Not .Value 5 Me.CheckBox4.Enabled = Not .Value 6 End With 7End Sub

違うものなのに区別せずごっちゃにしてますね?
まずは違いを認識してください。

あーフォームコントロールの方は、
シートの保護をしないとクリック出来ちゃいますねー。
もう一工夫必要ですが、ちょっと時間切れです。

次、いつ回答できるか解らないので、
他の方の回答をお待ちください。

投稿2020/03/24 08:34

編集2020/03/24 10:11
mattuwan

総合スコア2163

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2020/03/24 08:41

すみません、フォームコントロールの方です。 よろしくお願いいたします。
退会済みユーザー

退会済みユーザー

2020/03/24 13:18

色々とありがとうございました! フォームコントロールとActiveXコントロールでコードが違うのは 知っていましたが、これでも動いたのでいけると思ってしまっていました汗。 ご指摘ありがとうございます! あと続きは私の方でももう少し考えてみますね。 色々とありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問