エクセルで作成したグループ化させた図形(テキスト入力あり)を「元の書式を保持」したまま
パワーポイントのシートの位置や貼付大きさを指定した上で貼り付けがしたいです。
しかし実行すると以下のエラーメッセージが表示さえ、パワーポイントへの貼り付けが行えないです。
原因と対処方法を教えてほしいです。
発生している問題・エラーメッセージ
オブジェクトは、このプロパティまたはメソッドをサポートしていません。
該当のソースコード
VBA
1Public Name As Object 'オブジェクト名 2Public SldNmb As Integer 'スライド番号 3Public Top As Integer '上からの位置 4Public Left As Integer '左からの位置 5Public Width As Integer '横幅 6Public Odr As Integer '順番 7 8Property Get Self() As Class1 9 Set Self = Me '自己参照 10End Property 11 12Function CreateNew(NewName As Object, NewSldNmb As Integer, NewTop As Integer, _ 13 NewLeft As Integer, NewWidth As Integer, NewOdr As Integer) As Class1 14 With New Class1 15 Set .Name = NewName 'オブジェクト名 16 .SldNmb = NewSldNmb 'スライド番号 17 .Top = NewTop '上からの位置 18 .Left = NewLeft '左からの位置 19 .Width = NewWidth '横幅 20 .Odr = NewOdr '順番 21 Set CreateNew = .Self '作成したインスタンスを返す 22 End With 23End Function
VBA
1Sub オートシェイプ一斉貼り付け() 2 'コレクション生成 3 Dim Objs As Collection: Set Objs = New Collection 4 5 'シート名を変数へセット 6 Dim s1 As Worksheet: Set s1 = Sheets("シート1") 7 Dim s2 As Worksheet: Set s1 = Sheets("シート2") 8 9 '各要素をコレクションにセット 10 'オブジェクト名, スライド番号, 上からの位置, 左からの位置, 横幅, 順番(0→最前面 1→最背面) の順で 11 With New Class1 12 Objs.Add .CreateNew(s1.Shapes.Range(Array("Group 1")), 2, 50, 10, 600, 0) 13 Objs.Add .CreateNew(s1.Shapes.Range(Array("Group 4")), 2, 50, 10, 600, 0) 14 15 Objs.Add .CreateNew(s2.Shapes.Range(Array("Group 1")), 3, 50, 10, 600, 0) 16 Objs.Add .CreateNew(s2.Shapes.Range(Array("Group 4")), 3, 50, 10, 600, 0) 17 End With 18 19 'PPTの準備 20 On Error GoTo ERROR_HANDLER 21 Dim ppApp As Object: Set ppApp = CreateObject("PowerPoint.Application") 'PPTアプリ 22 Dim pp As Object: Set pp = ppApp.ActivePresentation 'PPTプレゼン 23 Dim ppSld As Object 'PPTスライド 24 25 Dim Obj As Class1 26 For Each Obj In Objs 'Objsコレクションをループ 27 Obj.Name.CopyPicture xlScreen, xlPicture '指定オブジェクトをクリップボードにコピー 28 Set ppSld = pp.Slides(Obj.SldNmb) 'PowerPointスライド指定 29 ppSld.Shapes.Paste '貼り付け 30 31 '位置・サイズを補正 32 With ppSld.Shapes(ppSld.Shapes.Count) '最終シェイプを指定 33 .LockAspectRatio = msoTrue '縦横比固定 34 .Top = Obj.Top '上からの位置 35 .Left = Obj.Left '左からの位置 36 .Width = Obj.Width '横幅 37 .ZOrder Obj.Odr '移動 38 End With 39 Next 40 41TERMINATE: 42 On Error GoTo 0 43 Set ppApp = Nothing 44 Set pp = Nothing 45 Set ppSld = Nothing 46 Exit Sub 47 48ERROR_HANDLER: 49 MsgBox Err.Description, vbCritical 50 Resume TERMINATE 51End Sub
補足事項
貼り付け先のパワーポイントは、指定されているスライドがすべて存在していて、既に開いているのが条件です。
あなたの回答
tips
プレビュー