Работа с фигурами в VBA Excel: создание фигур методом Shapes.AddShape, типы фигур (MsoAutoShapeType), обращение к фигурам и изменение их свойств. Примеры.
Объекты для работы с фигурами
Фигуры в VBA Excel представлены тремя объектами:
Объект | Описание |
---|---|
Shapes | Коллекция всех фигур на рабочем листе. Используется для создания новых фигур, для обращения к одной фигуре по имени и для перебора фигур циклом. |
ShapeRange | Коллекция нескольких фигур, аргументом которой является массив имен выбранных объектов. Используется для редактирования сразу всех фигур, входящих в эту коллекцию. |
Shape | Объект, представляющий одну фигуру. Используется для редактирования одной этой фигуры. |
Создание фигур в VBA Excel
Фигуры в VBA Excel создаются методом Shapes.AddShape.
Синтаксис метода AddShape
1 |
Shapes.AddShape (Type, Left, Top, Width, Height) |
Shapes — выражение, возвращающее коллекцию фигур на рабочем листе, например: ActiveSheet.Shapes.
Параметры метода AddShape
Параметр | Описание |
---|---|
Type | Константа из коллекции MsoAutoShapeType, определяющая тип создаваемой фигуры. |
Left | Расстояние от левой границы фигуры до левой границы табличной части рабочего листа в пунктах.. Тип данных — Single. |
Top | Расстояние от верхней границы фигуры до верхней границы табличной части рабочего листа в пунктах.. Тип данных — Single. |
Width | Ширина фигуры по внешним границам в пунктах. |
Height | Высота фигуры по внешним границам в пунктах. |
Все параметры метода Shapes.AddShape являются обязательными.
Константы MsoAutoShapeType
Константы коллекции MsoAutoShapeType, определяющие основные типы создаваемых фигур:
Константа | Значение | Тип фигуры |
---|---|---|
msoShapeRectangle | 1 | Прямоугольник |
msoShapeParallelogram | 2 | Параллелограмм |
msoShapeTrapezoid | 3 | Трапеция |
msoShapeDiamond | 4 | Ромб |
msoShapeRoundedRectangle | 5 | Прямоугольник: скругленные углы |
msoShapeOctagon | 6 | Восьмиугольник (октаэдр) |
msoShapeIsoscelesTriangle | 7 | Равнобедренный треугольник |
msoShapeRightTriangle | 8 | Прямоугольный треугольник |
msoShapeOval | 9 | Овал |
msoShapeHexagon | 10 | Шестиугольник (гексаэдр) |
msoShapeCross | 11 | Крест |
msoShapeRegularPentagon | 12 | Пятиугольник (пентаэдр) |
msoShapeCan | 13 | Цилиндр |
msoShapeCube | 14 | Куб |
msoShapeDonut | 18 | Круг: прозрачная заливка (кольцо) |
msoShapeLightningBolt | 22 | Молния |
msoShapeSun | 23 | Солнце |
msoShapeMoon | 24 | Месяц (луна) |
msoShape5pointStar | 92 | Звезда: 5 точек (пятиконечная) |
msoShapeCloud | 179 | Облако |
Все доступные константы из коллекции MsoAutoShapeType смотрите на сайте разработчиков.
Создание объекта ShapeRange
Создание коллекции ShapeRange из выбранных фигур:
1 2 |
Dim myShapeRange As ShapeRange Set myShapeRange = ActiveSheet.Shapes.Range(Array("Пятиугольник 140", "Солнце 141", "Облако 144")) |
Объектная переменная myShapeRange не обязательна, можно обратиться непосредственно к возвращенной коллекции, например, присвоив всем ее элементам синий цвет:
1 |
ActiveSheet.Shapes.Range(Array("Пятиугольник 140", "Солнце 141", "Облако 144")).Fill.ForeColor.RGB = vbBlue |
Примеры работы с фигурами
Пример 1
Создание пяти разных фигур из кода VBA Excel методом Shapes.AddShape:
1 2 3 4 5 6 7 8 9 10 11 |
Sub Primer1() With ActiveSheet.Shapes 'При создании фигуры без присвоения ее переменной скобки не нужны .AddShape msoShapeCube, 30, 40, 72, 72 .AddShape msoShapeIsoscelesTriangle, 130, 40, 72, 72 .AddShape msoShapeSun, 230, 40, 72, 72 .AddShape msoShapeLightningBolt, 330, 40, 72, 72 'Чтобы выбрать фигуру, параметры необходимо заключить в скобки .AddShape(msoShapeCloud, 430, 40, 72, 72).Select End With End Sub |
Результат работы кода:
Пример 2
Работа с одной фигурой:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
Sub Primer2() Dim myShape As Shape 'Создаем фигуру "Месяц" и присваивает ссылку на нее переменной myShape Set myShape = ActiveSheet.Shapes.AddShape(msoShapeMoon, 50, 50, 80, 80) With myShape 'Меняем высоту и ширину фигуры .Height = 150 .Width = 100 'Меняем цвет фигуры .Fill.ForeColor.RGB = vbYellow 'Поворачиваем фигуру влево на 40 градусов .Rotation = -40 End With End Sub |
Пример 3
Редактирование одновременно нескольких фигур с помощью коллекции ShapeRange:
1 2 3 4 5 6 7 8 9 10 11 |
Sub Primer3() With ActiveSheet.Shapes.Range(Array("Овал 1", "Овал 2", "Овал 3")) 'Меняем цвет всех фигур из коллекции ShapeRange .Fill.ForeColor.RGB = vbBlue 'Задаем высоту и ширину овалов .Height = 150 .Width = 50 'Поворачиваем фигуры вправо на 45 градусов .Rotation = 45 End With End Sub |
Пример 4
Редактирование одновременно всех фигур на рабочем листе с помощью коллекции ShapeRange:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
Sub Primer4() Dim myShapeRange As ShapeRange, i As Integer, _ myShape As Shape, myArray() As String 'Задаем массиву размерность от 1 до количества фигур на листе ReDim myArray(1 To ActiveSheet.Shapes.Count) 'Проходим циклом по всем фигурам коллекции и записываем их имена в массив For Each myShape In ActiveSheet.Shapes i = i + 1 myArray(i) = myShape.Name Next 'Создаем коллекцию ShapeRange и присваиваем ссылку на нее переменной myShapeRange Set myShapeRange = ActiveSheet.Shapes.Range(myArray) With myShapeRange 'Изменяем цвет всех фигур на рабочем листе .Fill.ForeColor.RGB = RGB(100, 150, 200) 'Поворачиваем все фигуры вокруг вертикальной оси .Flip msoFlipVertical End With End Sub |
Пример 5
Добавление надписи (текста) на фигуру:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
Sub Primer5() Dim myShape As Shape Set myShape = ActiveSheet.Shapes.AddShape(msoShapeCloud, 50, 30, 300, 300) With myShape.TextFrame2 'Добавление текста на фигуру .TextRange.Characters.Text = "Объект TextFrame представляет текстовую рамку в объекте Shape. Содержит текст в текстовом кадре, а также свойства и методы, которые контролируют выравнивание и закрепление текстового кадра." 'Задаем курсивное начертание .TextRange.Characters.Font.Italic = True 'Указываем размер шрифта .TextRange.Characters.Font.Size = 13 'Отступ левой границы текстового поля от левой внутренней границы фигуры .MarginLeft = 30 'Отступ верхней границы текстового поля от верхней внутренней границы фигуры .MarginTop = 20 End With End Sub |
Результат работы кода:
Изменить цвет текста, например на черный, можно двумя способами:
1 2 3 4 |
'С помощью константы MsoThemeColorIndex myShape.TextFrame2.TextRange.Characters.Font.Fill.ForeColor.ObjectThemeColor = msoThemeColorDark1 'С помощью цветовой модели RGB myShape.TextFrame2.TextRange.Characters.Font.Fill.ForeColor.RGB = RGB(0, 0, 0) |
С константами из коллекции MsoThemeColorIndex вы можете ознакомиться на сайте разработчиков.
Пример 6
Удаление фигур с рабочего листа из кода VBA Excel с помощью метода Delete.
Удаление одной фигуры:
1 |
ActiveSheet.Shapes("Ромб 5").Delete |
Удаление нескольких фигур:
1 |
ActiveSheet.Shapes.Range(Array("Овал 1", "Овал 2", "Овал 3")).Delete |
Удаление всех фигур с рабочего листа с помощью цикла:
1 2 3 4 5 6 |
Sub Primer6() Dim myShape As Shape For Each myShape In ActiveSheet.Shapes myShape.Delete Next End Sub |
В 7 примере рассмотрено удаление всех фигур без цикла.
Пример 7
Выделение всех фигур на рабочем листе:
1 |
ActiveSheet.Shapes.SelectAll |
Выбор всех фигур и удаление выбранного (всех фигур):
1 2 3 4 |
Sub Primer7() ActiveSheet.Shapes.SelectAll Selection.Delete End Sub |
Продолжение темы в статье VBA Excel. Копирование, перемещение и поворот фигур.
Евгений,здравствуйте! Еще раз спасибо большое за Вашу помощь.
Прошу прощения что вновь задаю вопрос,но в этот же документе теперь появилась другая проблема. Как я понимаю она опять-таки связана с макросом.
Текст при необходимости переносится на вторую строку,но при выводе на печать во всех полях печатается только то что попадает в первую строку.
Здравствуйте, Евгения!
Попробуйте закомментировать
и ниже вставить
Евгений, здравствуйте! Все сделала — не помогает.
Выяснила что до того как удалось починить поле «один» на печать выводилось обе строки в полях.
Здравствуйте, Евгения!
По идее, на печать должно выводиться также, как видно на листе. Попробуйте покликать по надписям на листе, посмотрите, текст выходит за рамки ограничительных линий или нет.
Евгений, здравствуйте! Все заработало отлично! Не знаю что произошло, но вдруг все стало работать!). Еще раз примите мою искреннюю благодарность и восхищение Вашими знаниями.
Здравствуйте. На листе имеется Shapes(1) — диаграмма и Shapes(2) — картинка. Нужно чтобы заливка диаграммы была в виде рисунка с листа и затем удалить связи диаграммы с данными. Сделал как вставку с буфера, но ошибка в строке с меткой 1, как удалить связи не знаю:
ActiveSheet.Shapes(2).Copy
With ActiveSheet.Shapes(1).Fill
1 .UserPicture .Paste
.TextureTile = msoFalse
End With
Здравствуйте, Фарит!
Для заливки можно использовать только изображения с диска:
Добрый день!
Хотел бы попросить у Вас помощи с написанием макроса. Раньше не занимался ни макросами ни VBA, только начал осваивать эту сферу.
По данным таблицы макрос должен рисовать фигуру (прямоугольник), выводить на ней надпись, и сохранять цвет фона пока выполняются условия.
Следуя примерам данного раздела у меня вышло написать макрос только для одного значения:
Sub Primer1()
With ActiveSheet.Shapes
Set myShape1 = ActiveSheet.Shapes.AddShape(msoShapeRectangle, 400, 40, Worksheets(1).Range("E3") * 72, Worksheets(1).Range("F3") * 72)
With myShape1
.Fill.ForeColor.RGB = vbYellow
.Fill.Transparency = 0.4
.DrawingObject.Caption = Worksheets(1).Range("B3")
With myShape1.TextFrame2
.TextRange.Characters.Font.Size = 45
.TextRange.Characters.Font.Fill.ForeColor.ObjectThemeColor = msoThemeColorDark1
End With
End With
End With
End Sub
Приходиться копировать код для следующих значений и вводить ссылки на ячейки вручную и т.д.
Но так как таблица не маленькая, прошу подсказать как задать макросу выборку нужных параметров из таблицы.
Спасибо!
Здравствуйте.
Кнопка с панели формы в MSExcel (не элементы управления) вроде тоже относится к объекту shape.
Однако не получается изменить цвет заливки. Код vba
Dim myShape As Shape
Set myShape = ThisWorkbook.Worksheets("Sheet1").Shapes("Button 6")
Debug.Print myShapes.Fill.ForeColor.RGB
myShapes.Fill.ForeColor.RGB = vbYellow 'RGB(255, 0, 0) '15790320 + 10000
myShapes.Fill.BackColor.RGB = vbYellow 'RGB(255, 0, 0) '15790320 + 10000
Может подскажите в чём секрет?
Здравствуйте, Владислав!
Цвет заливки у элементов управления формы, которые вставляются на рабочий лист, не редактируется, но вы можете создать кнопку как фигуру (прямоугольник), у которой можно менять заливку, вставить надпись и назначить макрос через контекстное меню.
Понял. Спасибо. Может подскажете где найти описание свойств коллекции Buttons/Button листа?
Set myButton = ThisWorkbook.Worksheets("Sheet1").Buttons("Button 6")
Debug.Print myButton.Name
Доступные свойства вы можете просмотреть, кликнув по элементу управления формы правой кнопкой мыши и выбрав в контекстном меню «Формат объекта».
Спасибо
Здравствуйте. Есть фигура бублик — msoShapeDonut, к середине этой фигуры надо прикрепить стрелку -msoConnectorStraight своим началом. Т.е. что бы от центра бублика исходила стрелка (для векторной диаграммы). Не могу понять как сделать, у бублика узнаю координаты, вычисляю таким образом середину, прописывают в стрелку бегинХ и бегинУ эту точку, в итоге стрелка сползает непонять куда. Разбирался, не понял нихрена, пытался пересчитать на пункты что то не выходит совсем. Как сделать это? Можно ли как то самому в классе создать фигуру. у которой будет центральная точка что бы привязать к ней? Вот два основных вопроса.
А ещё свойство ротатион поворачивает относительно центра фигуры, как сделать относительно начала фигуры бегинХ,У? И тот же бублик крутится относительно центра, а самого центра нет:( . Не могу разобраться, помоги
Здравствуйте, Евгений. Есть ли возможность фигуру залить картинкой и чтобы фигура полностью соответствовала размерам этой картинки?
Здравствуйте, Сергей!
Ответ дал в последнем параграфе статьи VBA Excel. Свойства файла — вывод информации о файле.
Спасибо Евгений, очень полезная статья. Обязательно пригодится в каких-нибудь моих проектах. Хочу опубликовать вариант, если вы не против, который накопал сам. Возможно еще кому-то будет полезно.
Public Sub PictureToClipboard(ByVal путь As String)
Dim y As Shape
'Как раз в следующей строке создается фигура типа картинка (addPicture) c залитая изображением, заданным ссылкой на файл (ПУТЬ). И последние два параметра равные -1 говорят системе, что нужно использовать разрешение самого файла (ширина=-1, высота=-1), а не фигуры. То есть фигура подстраивается под размер файла.
Set y = Workbooks(dvName).Sheets("Лист2").Shapes.AddPicture(путь, True, False, 0, 0, -1, -1)
y.Line.Visible = msoFalse
y.LockAspectRatio = msoFalse
y.CopyPicture Format:=xlBitmap
y.Delete
Set y = Nothing
End Sub
Обсуждение закрыто.