0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

Excel VBA 数字のオートシェイプを作る

Last updated at Posted at 2021-10-31

image.png

色々悔いが残るサンプル

出現する位置がバラバラ

作る位置を統一していなかったので、バラバラに出現する
標準だとA列からAE列
行は1行目から54行目。

大きさもバラバラ

マウスで作っているので、大きさは調整

運用もバラバラ

大きさは適当に縮小して使う。角度は回転を使う。

そのばしのぎ

9は6をひっくり返して使う。
8は1シートに一つしか作れない。
これは円を2つ重ねてグループ化するため
このため0は8をつくってから使う。

言い訳

当然描画しなおしたいと思うのだが、塗りつぶしになるには始点と終点が合わないといけない。
これは終点を始点に近づけて、重ね合わせているとしばらくするとなったりする。文字だとわかりづらいが、しばらくやってみるとわかると思う。
作り直しが難しいのも、一筆書きということで、コード上で数値の修正ができないため。少し間違うと始点と終点が一致しない。
このように不格好であるが、サイズは割と自由で、塗りつぶしの色を変えたり、印刷しない設定にしたりできる。詳しくは公式のサイトを見るといいと思う。
通常であればテキストボックスを使うことが前提だと思う。

オートシェイプに数字の形はない

意外なことにオートシェイプに数字の形はない。
アイコンにもない。
今回無理やり作ったもので、仕事で使うのは微妙だが、かといっていちから作るのも大変。
なので、使用は進めない。
また、フリーフォームでは8を作ると一筆書き風になるため作るのが難しい。

クリップアートが廃止

また、マクロでなくても、とは思うのだが、今はクリップアートに登録できない。クリップアートは廃止されてしまった。
このため、テキストボックス以外では画像として保存するか、マクロを組んでおいて数字を作り出すしかないようだ。

図形を追加する
線またはコネクタを描画または削除する
フリーフォーム図形の描画または編集

サンプル

' Excel VBA
' Make Number Figure Shape

Sub Number01()
' Number01 Macro

    With ActiveSheet.Shapes.BuildFreeform(msoEditingAuto, 1601.25, 330)
        .AddNodes msoSegmentLine, msoEditingAuto, 1610.6249606299, 343.1249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1642.5, 324.3749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1642.5, 444.3749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1642.5, 444.3749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1635, 468.75
        .AddNodes msoSegmentLine, msoEditingAuto, 1659.3749606299, 468.75
        .AddNodes msoSegmentLine, msoEditingAuto, 1659.3749606299, 301.8749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1601.25, 330
        .ConvertToShape.Select
    End With
End Sub
Sub Number02()
'
' Number02 Macro
'

'
    With ActiveSheet.Shapes.BuildFreeform(msoEditingAuto, 1605, 388.1249606299)
        .AddNodes msoSegmentLine, msoEditingAuto, 1621.8749606299, 410.6249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1644.3749606299, 390
        .AddNodes msoSegmentLine, msoEditingAuto, 1665, 382.5
        .AddNodes msoSegmentLine, msoEditingAuto, 1683.75, 384.3749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1698.75, 408.75
        .AddNodes msoSegmentLine, msoEditingAuto, 1700.6249606299, 436.8749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1696.8749606299, 461.25
        .AddNodes msoSegmentLine, msoEditingAuto, 1670.6249606299, 478.1249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1633.1249606299, 485.6249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1614.3749606299, 489.3749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1605, 515.6249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1788.75, 513.75
        .AddNodes msoSegmentLine, msoEditingAuto, 1783.1249606299, 489.3749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1728.75, 491.25
        .AddNodes msoSegmentLine, msoEditingAuto, 1713.75, 491.25
        .AddNodes msoSegmentLine, msoEditingAuto, 1725, 474.3749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1734.3749606299, 436.8749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1740, 401.25
        .AddNodes msoSegmentLine, msoEditingAuto, 1719.3749606299, 371.25
        .AddNodes msoSegmentLine, msoEditingAuto, 1700.6249606299, 361.8749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1683.75, 361.8749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1659.3749606299, 361.8749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1648.1249606299, 365.6249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1627.5, 373.1249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1627.5, 373.1249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1605, 388.1249606299
        .ConvertToShape.Select
    End With
End Sub
Sub Number3()
'
' Number3 Macro
'

'
    With ActiveSheet.Shapes.BuildFreeform(msoEditingAuto, 1816.8749606299, 431.25)
        .AddNodes msoSegmentLine, msoEditingAuto, 1792.5, 412.5
        .AddNodes msoSegmentLine, msoEditingAuto, 1822.5, 390
        .AddNodes msoSegmentLine, msoEditingAuto, 1856.25, 367.5
        .AddNodes msoSegmentLine, msoEditingAuto, 1912.5, 367.5
        .AddNodes msoSegmentLine, msoEditingAuto, 1931.25, 390
        .AddNodes msoSegmentLine, msoEditingAuto, 1946.25, 421.8749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1953.75, 453.75
        .AddNodes msoSegmentLine, msoEditingAuto, 1925.6249606299, 468.75
        .AddNodes msoSegmentLine, msoEditingAuto, 1890, 481.8749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1854.3749606299, 481.8749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1856.25, 500.6249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1921.8749606299, 498.75
        .AddNodes msoSegmentLine, msoEditingAuto, 1978.1249606299, 517.5
        .AddNodes msoSegmentLine, msoEditingAuto, 2008.1249606299, 570
        .AddNodes msoSegmentLine, msoEditingAuto, 1978.1249606299, 601.8749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1890, 630
        .AddNodes msoSegmentLine, msoEditingAuto, 1818.75, 620.6249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1818.75, 596.25
        .AddNodes msoSegmentLine, msoEditingAuto, 1876.8749606299, 600
        .AddNodes msoSegmentLine, msoEditingAuto, 1933.1249606299, 590.6249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1963.1249606299, 575.6249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1972.5, 562.5
        .AddNodes msoSegmentLine, msoEditingAuto, 1953.75, 528.75
        .AddNodes msoSegmentLine, msoEditingAuto, 1918.1249606299, 526.8749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1871.25, 526.8749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1837.5, 526.8749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1835.6249606299, 459.3749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1880.6249606299, 461.25
        .AddNodes msoSegmentLine, msoEditingAuto, 1921.8749606299, 450
        .AddNodes msoSegmentLine, msoEditingAuto, 1933.1249606299, 444.3749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1940.6249606299, 427.5
        .AddNodes msoSegmentLine, msoEditingAuto, 1923.75, 399.3749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1893.75, 386.25
        .AddNodes msoSegmentLine, msoEditingAuto, 1863.75, 395.6249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1843.1249606299, 406.8749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1822.5, 416.25
        .AddNodes msoSegmentLine, msoEditingAuto, 1816.8749606299, 431.25
        .ConvertToShape.Select
    End With

End Sub
Sub Number04()
'
' Number04 Macro
'

'
    With ActiveSheet.Shapes.BuildFreeform(msoEditingAuto, 1625.6249606299, 345)
        .AddNodes msoSegmentLine, msoEditingAuto, 1595.6249606299, 423.75
        .AddNodes msoSegmentLine, msoEditingAuto, 1663.1249606299, 418.1249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1665, 480
        .AddNodes msoSegmentLine, msoEditingAuto, 1693.1249606299, 480
        .AddNodes msoSegmentLine, msoEditingAuto, 1691.25, 418.1249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1734.3749606299, 414.3749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1734.3749606299, 388.1249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1696.8749606299, 391.8749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1695, 371.25
        .AddNodes msoSegmentLine, msoEditingAuto, 1661.25, 373.1249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1663.1249606299, 393.75
        .AddNodes msoSegmentLine, msoEditingAuto, 1633.1249606299, 397.5
        .AddNodes msoSegmentLine, msoEditingAuto, 1674.3749606299, 305.6249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 1644.3749606299, 300
        .AddNodes msoSegmentLine, msoEditingAuto, 1625.6249606299, 345
        .ConvertToShape.Select
    End With
End Sub
Sub Number05()
'
' Number05 Macro
'


    With ActiveSheet.Shapes.BuildFreeform(msoEditingAuto, 1146.9100787402, _
        594.9438582677)
        .AddNodes msoSegmentLine, msoEditingAuto, 1190.7303149606, 594.9438582677
        .AddNodes msoSegmentLine, msoEditingAuto, 1191.5730708661, 605.8988976378
        .AddNodes msoSegmentLine, msoEditingAuto, 1160.3932283465, 605.8988976378
        .AddNodes msoSegmentLine, msoEditingAuto, 1159.5505511811, 626.1236220472
        .AddNodes msoSegmentLine, msoEditingAuto, 1187.3595275591, 627.808976378
        .AddNodes msoSegmentLine, msoEditingAuto, 1194.9438582677, 643.8202362205
        .AddNodes msoSegmentLine, msoEditingAuto, 1193.2584251969, 657.3033858268
        .AddNodes msoSegmentLine, msoEditingAuto, 1155.3370866142, 658.1460629921
        .AddNodes msoSegmentLine, msoEditingAuto, 1152.808976378, 658.1460629921
        .AddNodes msoSegmentLine, msoEditingAuto, 1154.4944094488, 648.0337007874
        .AddNodes msoSegmentLine, msoEditingAuto, 1183.1460629921, 648.0337007874
        .AddNodes msoSegmentLine, msoEditingAuto, 1183.1460629921, 640.4494488189
        .AddNodes msoSegmentLine, msoEditingAuto, 1178.0899212598, 637.0786614173
        .AddNodes msoSegmentLine, msoEditingAuto, 1154.4944094488, 636.235984252
        .AddNodes msoSegmentLine, msoEditingAuto, 1153.6516535433, 636.235984252
        .AddNodes msoSegmentLine, msoEditingAuto, 1151.9662992126, 636.235984252
        .AddNodes msoSegmentLine, msoEditingAuto, 1146.9100787402, 594.9438582677
        .ConvertToShape.Select
    End With
End Sub
Sub Number06()
'
' Number06 Macro
'

'
    With ActiveSheet.Shapes.BuildFreeform(msoEditingAuto, 45.5357480315, _
        192.8571653543)
        .AddNodes msoSegmentLine, msoEditingAuto, 72.3214173228, 192.8571653543
        .AddNodes msoSegmentLine, msoEditingAuto, 72.3214173228, 254.4642519685
        .AddNodes msoSegmentLine, msoEditingAuto, 128.5714173228, 254.4642519685
        .AddNodes msoSegmentLine, msoEditingAuto, 127.2321259843, 328.1249606299
        .AddNodes msoSegmentLine, msoEditingAuto, 44.1964566929, 326.7857480315
        .AddNodes msoSegmentLine, msoEditingAuto, 46.8749606299, 308.0357480315
        .AddNodes msoSegmentLine, msoEditingAuto, 108.4821259843, 309.3749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 107.1428346457, 279.9107086614
        .AddNodes msoSegmentLine, msoEditingAuto, 72.3214173228, 279.9107086614
        .AddNodes msoSegmentLine, msoEditingAuto, 69.6428346457, 305.3571653543
        .AddNodes msoSegmentLine, msoEditingAuto, 48.2142519685, 301.3392913386
        .AddNodes msoSegmentLine, msoEditingAuto, 45.5357480315, 192.8571653543
        .ConvertToShape.Select
    End With
    Selection.ShapeRange.ScaleWidth 0.9523816634, msoFalse, msoScaleFromBottomRight
    Selection.ShapeRange.ScaleHeight 0.9207922925, msoFalse, msoScaleFromTopLeft
    Selection.ShapeRange.ScaleWidth 0.733333268, msoFalse, msoScaleFromBottomRight
    Selection.ShapeRange.ScaleHeight 0.4623651088, msoFalse, msoScaleFromTopLeft
    Selection.ShapeRange.ScaleWidth 0.7954563979, msoFalse, msoScaleFromTopLeft
    Selection.ShapeRange.ScaleHeight 0.9302349111, msoFalse, _
        msoScaleFromBottomRight
End Sub
Sub Number07()
'
' Number07 Macro
'

'
    With ActiveSheet.Shapes.BuildFreeform(msoEditingAuto, 50.8928346457, _
        218.3035433071)
        .AddNodes msoSegmentLine, msoEditingAuto, 73.6607086614, 220.9821259843
        .AddNodes msoSegmentLine, msoEditingAuto, 72.3214173228, 203.5714173228
        .AddNodes msoSegmentLine, msoEditingAuto, 105.8035433071, 207.5892913386
        .AddNodes msoSegmentLine, msoEditingAuto, 104.4642519685, 278.5714173228
        .AddNodes msoSegmentLine, msoEditingAuto, 124.5535433071, 281.25
        .AddNodes msoSegmentLine, msoEditingAuto, 124.5535433071, 198.2142519685
        .AddNodes msoSegmentLine, msoEditingAuto, 61.6071653543, 196.8749606299
        .AddNodes msoSegmentLine, msoEditingAuto, 50.8928346457, 218.3035433071
        .ConvertToShape.Select
    End With

    Selection.ShapeRange.ScaleWidth 0.9090915893, msoFalse, msoScaleFromTopLeft
    Selection.ShapeRange.ScaleHeight 0.841270182, msoFalse, msoScaleFromTopLeft
End Sub
Sub Number08Form()
'
' Number08Form Macro
'
Dim shps As Excel.Shapes, shp As Excel.Shape, shpr As Excel.ShapeRange, buf1 As String, buf2 As String
    ActiveSheet.Shapes.AddShape(msoShapeDonut, 81.6964566929, 171.4285826772, _
        52.2321259843, 42.8571653543).Select
    ActiveSheet.Shapes.AddShape(msoShapeDonut, 89.7321259843, 216.9642519685, _
        60.2678740157, 65.6250393701).Select
    Selection.ShapeRange.IncrementLeft -12.0535433071
    Selection.ShapeRange.IncrementTop -5.3571653543
For Each shp In ActiveSheet.Shapes
If shp.Name Like ("Donut*") Then
If buf1 = "" Then
buf1 = shp.Name
ElseIf buf2 = "" Then
buf2 = shp.Name
End If
End If
Next
    ActiveSheet.Shapes.Range(Array(buf1, buf2)).Select
    Selection.ShapeRange.Group.Select
End Sub
0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?