VBA Code


Adjustments Object

This object holds a collection of numbers used to move the adjustment handles of a Shape object.
Each shape object can have up to 8 different adjustments.
Each specific adjustment handle can have one or two adjustments associated with it depending on if it can be moved both horizontally and vertically.
Adjustment values are between 0 and 1 are are hence percentages.

'change the head of the arrow to start 30% of the way across
   objshape.Adjustments(1) = 0.3 'left/right
'set the shaft to start 40% of the way down
   objshape.Adjustments(2) = 0.4 'up/down


objShape.Type = msoShapeType.msoTextBox 

objShape.LockAspectRatio = msotristate.msotrue 


Dim objShape As Shape 
objShape.Placement = xlPlacement.xlFreeFloating

objShape.PrintObject = False 


ActiveShape.ScaleHeight 0.8, msoFalse, msoScaleFromBottomRight 

Dim sngposition As Single 
sngPosition = ActiveSheet.Shapes("Picture2").Top = sngPosition


Shapes - TextFrame



Shapes - TextBoxes

Identifying and changing

Sheets(1).Shapes("TextBox 2").TextFrame.Characters.Text = "some text" 


objShape = objWsh.Shapes.Item("Name") 
objTextFrame = objShape.TextFrame

A TextFrame property was added in Excel 2007 ??

objTextFrame = Characters.Text = "the text" 

Is there an error if you assign a zero length text ???


With ActiveSheet.Shapes(1).TextFrame 
   .Characters.Text = "some text"
   .Characters(1,4).Font.Bold = True
End With


Formatting

You can either specify the exact colour using the RGB function or you can use an index from the Colour Scheme

objShape.Fill.ForeColor.RGB = RGB(12, 12, 12) 
objShape.Fill.BackColor.RGB = RGB(12, 12, 12)
objShape.Line.ForeColor.RGB = RGB(12, 12, 12)
objShape.Line.BackColor.RGB = RGB(12, 12, 12)


ojShape.Fill.ForeColor.SchemeColor = 60 

The macro recorder will always record a mixture of both exact colours and colours from the Colour Scheme

objShape.Line.ForeColor.SchemeColor = 19 
objShape.Line.BackColor.RGB = RGB(255, 255, 255)

You do not have to use the SchemeColor property to define you ForeColor but can use the RGB instead

objShape.Line.ForeColor.RGB = RGB(255, 255, 255) 

Dim objShape As Excel.Shape 

   objShape.Line.ForeColor.RGB = Microsoft.VisualBasic.RGB(0, 0, 0)
   objShape.Line.BackColor.RGB = Microsoft.VisualBasic.RGB(255, 255, 255)
   objShape.Line.Visible = Office.MsoTriState.msoTrue
   objShape.Line.Weight = 0.75
   objShape.Line.DashStyle = Office.MsoLineDashStyle.msoLineSolid
   objShape.Line.Style = Office.MsoLineStyle.msoLineSingle
   objShape.Line.Transparency = 0.0#
   objShape.Line.Pattern = Office.MsoPatternType.msoPattern25Percent
   objShape.Line.BeginArrowheadLength = Office.MsoArrowheadLength.msoArrowheadLengthMedium
   objShape.Line.BeginArrowheadStyle = Office.MsoArrowheadStyle.msoArrowheadDiamond
   objShape.Line.BeginArrowheadWidth = Office.MsoArrowheadWidth.msoArrowheadWide
   objShape.Line.EndArrowheadLength = Office.MsoArrowheadLength.msoArrowheadLengthMixed
   objShape.Line.EndArrowheadStyle = Office.MsoArrowheadStyle.msoArrowheadDiamond
   objShape.Line.EndArrowheadWidth = Office.MsoArrowheadWidth.msoArrowheadWidthMedium

   objShape.Fill.BackColor.RGB = Microsoft.VisualBasic.RGB(255, 255, 255)
   objShape.Fill.ForeColor.RGB = Microsoft.VisualBasic.RGB(255, 255, 255)
   objShape.Fill.OneColorGradient(Office.MsoGradientStyle.msoGradientDiagonalDown, 2, 2)
   objShape.Fill.TwoColorGradient(Office.MsoGradientStyle.msoGradientDiagonalDown, 3)
   objShape.Fill.Transparency = 0
   objShape.Fill.Visible = Office.MsoTriState.msoTrue
   objShape.Fill.Patterned(Office.MsoPatternType.msoPattern10Percent)

Applying Solid Fill

oShape.Fill.Solid 
oShape.Fill.ForeColor.RGB = RGB(5,5,5)

Applying Gradient Fill

oShape.Fill.ResetTextured msoTextureSand 

Removing Fill

oShape.Fill.Visible = Office.msoTristate.msoFalse 


Sub BET_DisplayColourScheme() 
Dim inumber As Integer

   For inumber = 1 To 80
      Range("A" & inumber + 1).Value = inumber

      ActiveSheet.Shapes.AddShape(msoShapeRectangle, 47.25, inumber * 12.75, 93.75, 12.75).Select
      Selection.ShapeRange.Fill.Visible = msoTrue
      Selection.ShapeRange.Fill.Solid
      Selection.ShapeRange.Fill.ForeColor.SchemeColor = inumber
      Selection.ShapeRange.Fill.Transparency = 0#
   Next inumber
    
End Sub

Creates a picture (on OLE Object) from an existing file


Removing all the AutoShapes

Dim shpShade as Shape 
For Each shpShape in Sheets(1).Shapes
   If Left(shpShape.Name,9) = "AutoShape" Then
      shpShape.Delete
   End If
Next shpShape


Shapes - ShapeRange


A shaperange can contain a single shape or all the shapes on a worksheet
You can create a shape range collection and add specific shapes to it
Use Selection.ShapeRange to return all the shapes in the current selection.


Dim objshaperange As Excel.ShapeRange 
Set objshaperange = ActiveSheet.Shapes.Range(Array(1,2))
                             ActiveSheet.Shapes.Range(1)
                             ActiveSheet.Shapes.Range("Line 1")
                             ActiveSheet.Shapes.SelectAll
                             ActiveSheet.Shapes.Range("Line 1","WordArt 2")
                             ActiveSheet.Shapes.Item("Line 1")


Adjusting Shape Sizes


depends on the zoom % of the worksheet
0.6 at 80%
is not 0.6 at 100% ???


Diagrams (new to 2002)

Access to the (Insert > Diagrams) objects is now possible through VBA through various DiagramXxx objects.





© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext