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

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

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

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

Q&A

2回答

995閲覧

ダブルクリックしたセルに数字の入った円形吹き出し図形を挿入したい

Beta

総合スコア0

VBA

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

1グッド

1クリップ

投稿2022/06/20 08:30

編集2022/06/20 11:28

VBA初心者です。ご教授願います。

ダブルクリックしたセルに数字の入った円形吹き出し図形を挿入したいです。
また、次にダブルクリックしてセルに図形を挿入したときに中の数字を+1カウントアップしたいです。(数字は1から始めます)

Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean) Dim StartX As Single Dim StartY As Single Dim EndX As Single Dim EndY As Single With Target 'Targetの左端 StartX = .Left 'Targetの上端 StartY = .Top 'Targetの横幅 EndX = 20 'Targetの高さ EndY = 20 '図形挿入 With ActiveSheet.Shapes.AddShape(msoShapeOvalCallout, StartX, StartY, EndX, EndY) With .TextFrame.Characters 'テキスト .Text = "1" '文字列 .Font.Size = 10 '文字のサイズ .Font.Bold = True End With End With Cancel = True End With End Sub

ネットの力を借りて、なんとかダブルクリックしたセルに数字の入った図形を挿入することはできました。

<問題点>
1.挿入した図形の色がデフォルトのままです。背景を白、枠線を赤に変えたいです。
2.中の数字が定数”1”のままです。追加するたびにカウントアップするようにしたいです。また、数字を中央にしたいです。
3.新たにシートを追加してもこの処理をできるようにしたいです。

<可能であれば>
セルに挿入するだけでなく、クリックした画像にも挿入することは可能でしょうか?

よろしくお願いいたします。

a22r1345👍を押しています

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

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

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

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

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

meg_

2022/06/20 10:59

コードはコード全体を「コードの挿入」で記入していただけませんか。
Beta

2022/06/20 11:30

すみません、変更しました。
hatena19

2022/06/20 12:39

カウントアップは一つのシート内でですか、それともブック全体ですか。 例 シート1で3回ダブルクリック 1、2,3とカウントアップ その後、シート2でダブルクリックしたら、4からですか、それとも1からですか。 また、シート上にこの円形吹き出し図形以外に図形は存在する可能性はありますか。 ブックを閉じるとき、この図形は残したまま保存しますか。
Beta

2022/06/20 13:03

カウントアップはシート内です。別のシートに移った場合、また1からスタートです。 シート上には四角の図形が存在する場合があります。 ブックを閉じるときは、図形を残したまま保存したいです。
guest

回答2

0

まず、

3.新たにシートを追加してもこの処理をできるようにしたいです。

シートを追加したときにそのシートにイベントモジュールを追加するのは難しいです。
このような時は、THisWorkbook のシートイベントを使います。
これだと全シート共通の処理を一か所で記述できます。
追加したシートでも有効です。
ダブルクリックなら、
Private Sub Workbook_SheetBeforeDoubleClick(ByVal sh As Object, ByVal Target As Range, Cancel As Boolean)
になります。

カウントアップはシート内です。別のシートに移った場合、また1からスタートです。
シート上には四角の図形が存在する場合があります。
ブックを閉じるときは、図形を残したまま保存したいです。

これでカウントアップするとなると、シート上にある図形をすべてしらべて、円形吹き出し図形のテキストで最大の値を取得する必要があります。これはそのような関数を作成します。

ThisWorkbookモジュール

vba

1Option Explicit 2 3Private Sub Workbook_SheetBeforeDoubleClick(ByVal sh As Object, ByVal Target As Range, Cancel As Boolean) 4 Dim StartX As Single 5 Dim StartY As Single 6 Dim EndX As Single 7 Dim EndY As Single 8 9 Cancel = True 10 11 With Target 12 'Targetの左端 13 StartX = .Left 14 'Targetの上端 15 StartY = .Top 16 'Targetの横幅 17 EndX = 20 18 'Targetの高さ 19 EndY = 20 20 21 '図形挿入 22 With sh.Shapes.AddShape(msoShapeOvalCallout, StartX, StartY, EndX, EndY) 23 With .TextFrame 24 With .Characters 'テキスト 25 .Text = GetNextNum(sh) '文字列 26 .Font.Size = 10 '文字のサイズ 27 .Font.Bold = True 28 .Font.Color = vbBlack '文字色 29 End With 30 .HorizontalAlignment = xlHAlignCenter '水平方向中央寄せ 31 .VerticalAlignment = xlVAlignCenter '垂直方向中央寄せ 32 End With 33 .Line.ForeColor.RGB = vbRed '枠線色 34 .Fill.ForeColor.RGB = vbWhite '背景色 35 End With 36 End With 37 38End Sub 39 40Function GetNextNum(sh As Worksheet) As Long 41 Dim shp As Shape 42 For Each shp In sh.Shapes 43 If shp.AutoShapeType = msoShapeOvalCallout Then 44 If GetNextNum < Val(shp.TextFrame.Characters.Text) Then 45 GetNextNum = shp.TextFrame.Characters.Text 46 End If 47 End If 48 Next shp 49 GetNextNum = GetNextNum + 1 50End Function

投稿2022/06/20 14:16

hatena19

総合スコア33757

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

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

0

 

投稿2022/06/20 14:20

編集2022/06/20 14:27
jinoji

総合スコア4585

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問