VBAかなりの初心者です。
先日、画像に添付したように、あらかじめテキストが入力されているセルを、ダブルクリックすると丸が付いたり消えたりするプログラムを教えてもらいました。
これはこれで使う機会があるので活用させてもらっているのですが。
できれば、ダブルクリックではなく、シングルクリックで丸が付いたり消えたりしたいのですが、できるでしょうか?
丸を付けたり消したりするセルには文字が入力されています。
丸をつけたり消したりしたいセルは時に結合されています。
丸をつけたり消したりしたいセルは連続していることもあれば、とびとびになっていることもあります。
前回教えて頂いたコードは以下のとおりです。
Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
'Mark の複数の範囲のセル/結合セルに Wクリックで 赤○ つける/消す
Dim Ad As String
Dim Lp As Single, Tp As Single, Hp As Single
Dim Ov As Oval, Mark As Range
Set Mark = Range("A5:b7, d5:e7, g5:h7,A1:B3") '範囲の複数指定
If Intersect(Target, Mark) Is Nothing Then Exit Sub '範囲外は無視
With Target
Ad = .Address: Hp = .Height: Tp = .Top
If .Height > .Width Then Hp = .Width '縦長結合の場合に備える
Lp = .Left + ((.Width / 2) - (Hp / 2))
End With
Cancel = True
7
With ActiveSheet
.Unprotect '★
For Each Ov In .Ovals
If Not (Intersect(Target, Ov.TopLeftCell) Is Nothing) Then '既存○検出
Ov.Delete: Ad = "": ' Exit For '◎重複があるなら外し、削除優先する
End If
Next
If Ad <> "" Then
With .Ovals.Add(Lp, Tp, Hp, Hp)
.Interior.ColorIndex = xlColorIndexNone
.Border.Color = vbRed ' 赤○にする
End With
End If
Protect , True, False, False '★
End With
End Sub
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
NO1です。
>できれば左シングルクリックがいいのでして・・・
⇒あいにく左シングルクリックだけのイベントは用意されいません。
近いイベントで「選択範囲が変わった時に発生」を利用しても良いのですが、
セル移動キー(方向キー、Tab、Enter)でも反応する、又削除する場合には
一旦範囲外に移動して戻るなど、操作上、紛らわしくなるのであえて
右クリックとした次第です。
多分、前回答の方もダブルクリックを選択されたのは、同じ様な理由と思います。
No.1
- 回答日時:
>ダブルクリックではなく、シングルクリックで丸が付いたり消えたりしたいのです
⇒右シングルクリックでは駄目でしょうか。
Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
↓
Private Sub Worksheet_BeforeRightClick(ByVal Target As Range, Cancel As Boolean)
又、次のコードをSet mark~の直前に移動して下さい。
Cancel = True
お返事ありがとうございます。
自分としては、本当はダブルクリックも右シングルクリックもOKなのですが。
できれば左シングルクリックがいいのでして・・・
すみません。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) 【VBA】写真の貼り付けコードがうまく機能しません。 5 2022/09/01 18:43
- Visual Basic(VBA) 【Excel VBA】自動メール送信の機能追加 5 2022/09/29 12:53
- Visual Basic(VBA) エクセルのVBAでダブルクリックでチェックを入れたあと 1 2022/10/26 20:30
- Visual Basic(VBA) 【追加】ファイルを閉じてダイアログで保存した時だけ処理の実行をする 3 2022/03/23 15:43
- Visual Basic(VBA) エクセルVBA ダブルクリックしたら色反転を指定したセルのみにしたい 2 2022/04/06 12:52
- Excel(エクセル) VBAについて 3 2022/06/19 18:19
- Excel(エクセル) Excel2019 マクロを使用し画像を貼り付けした際のリンク切れについて 2 2022/11/15 16:14
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 2 2022/05/26 17:19
- Excel(エクセル) 2つのVBAを一緒にしたら機能しなくなりました(エクセル) 7 2022/06/02 12:41
- Excel(エクセル) エクセル VBA For Next 繰り返しの書き方を教えてください 6 2022/09/01 14:11
このQ&Aを見た人はこんなQ&Aも見ています
-
性格の違いは生まれた順番で決まる?長男長女・中間子・末っ子・一人っ子の性格の傾向
同じ環境で生まれ育っても、生まれ順で性格は違うものなのだろうか。家庭教育研究家の田宮由美さんに教えてもらった。
-
セルをクリック⇒そのセルに入力された文字を○で囲む
Excel(エクセル)
-
Excelで丸をつけたい
Excel(エクセル)
-
エクセルで○をつけるマクロ設定
Excel(エクセル)
-
-
4
マクロを使って結合セルに丸を付ける+αな難題。。
Visual Basic(VBA)
-
5
エクセルで、選択した数字(セル)に赤の丸印をつけたい
Excel(エクセル)
-
6
エクセル初心者
Excel(エクセル)
-
7
セルをクリック⇒そのセルに入力された文字を○で囲む
Excel(エクセル)
-
8
エクセルマクロ セルをクリックするたびに記号を入力
Excel(エクセル)
-
9
セルの内容の条件に応じて図形の表示をしたりしなかったりする
Excel(エクセル)
-
10
エクセルマクロで結合されたセルをダブルクリックで指定文字を入力
Excel(エクセル)
-
11
エクセル ダブルクリック入力の範囲が複数の場合
Excel(エクセル)
-
12
複数セルに〇印をつけるマクロ
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBAで丸をつけたいです。
-
エクセルVBA(実行時エラー438...
-
EXCELマクロ 保護されているシ...
-
エクセルテキストボックスの文...
-
Excelについて
-
データが入力されている隣のセ...
-
VBAについて教えてください。 E...
-
エクセルVBA セル選択後にカレ...
-
ダブルクリックすると現在の時...
-
Excel VBA セルを指定個数ラン...
-
Swing 編集不可でも選択可能なJ...
-
セル色を5秒間隔で変える
-
Windowsで動くVBAがmacOSで動か...
-
エクセル マクロ 見つけてセ...
-
VBAで、貼り付け禁止命令を実現...
-
エクセル2007 VBA DTPicker
-
シート内セルに着色があればエ...
-
Excel VBAで結合されたセルの数
-
エクセルのVBAでダブルクリック...
-
GrapeCityのSpreadの複数セルの...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
データが入力されている隣のセ...
-
EXCELマクロ 保護されているシ...
-
エクセルテキストボックスの文...
-
VBAで、貼り付け禁止命令を実現...
-
Excelについて
-
メッセージを1度だけ表示したい。
-
ダブルクリックすると現在の時...
-
ハイパーリンクされているファ...
-
エクセルVBA セル選択後にカレ...
-
Jtableの特定のセルの背景色や...
-
VBAで丸をつけたいです。
-
エクセルVBA(実行時エラー438...
-
Excelのセル内にある図形を削除...
-
Swing 編集不可でも選択可能なJ...
-
(VBA)アクティブセルを起点に...
-
Excel VBA セルを指定個数ラン...
-
VBA セルに合わせて移動するが...
-
Windowsで動くVBAがmacOSで動か...
-
セル色を5秒間隔で変える
-
Excel VBA ダブルクリックで入...
おすすめ情報