Landscape Pages


Public Sub Layout_InsertLandscapePage() 
Dim lsectionno As Long
Dim oCurrentSection As Section
Dim oPreviousSection As Section
Dim oRange As Range

   lsectionno = Selection.Information(wdActiveEndSectionNumber)
   Set oCurrentSection = ActiveDocument.Sections(lsectionno)
   If (oCurrentSection.PageSetup.Orientation = wdOrientLandscape) Then
      Exit Sub
   End If
   Set oCurrentSection = Selection.Sections(1)
   Selection.MoveUp wdLine, 1
   Set oPreviousSection = Selection.Sections(1)
   Selection.MoveDown wdLine, 1
   If (oPreviousSection.Index = oCurrentSection.Index) Then
      Selection.TypeParagraph
      Selection.InsertBreak (wdSectionBreakNextPage)
      With Selection
          .TypeParagraph
          Set oRange = Selection.Range
          oRange.MoveStart wdParagraph, -1
          oRange.Select
          .Style = ActiveDocument.Styles("Heading 1")
          .TypeText "New Landscape Section"
          Set oRange = Selection.Range
          oRange.MoveStart wdParagraph, 1
          oRange.Select
          If (Selection_IsAtEndOfDocument = False) Then
             .TypeParagraph
             .TypeParagraph
             .InsertBreak (wdSectionBreakNextPage)
             .Delete
             Set oRange = Selection.Range
             oRange.Move wdParagraph, -3
             oRange.Select
          End If
          Call Layout_SwitchToLandscapeSection(True)
      End With
   Else
   End If
   Set oRange = Nothing
End Sub

Public Sub Layout_SwitchToLandscapeSection(ByVal bLinkToPrevious As Boolean) 
Dim lsectionno As Long
Dim oCurrentSection As Section
Dim oNextSection As Section
Dim oHeaderRange As Range
Dim oFooterRange As Range

   lsectionno = Selection.Information(wdActiveEndSectionNumber)
   Set oCurrentSection = ActiveDocument.Sections(lsectionno)
   If (oCurrentSection.PageSetup.Orientation = WdOrientation.wdOrientLandscape) Then
'do nothing
   Else
      If (ActiveDocument.Sections.Count > lsectionno) Then
          Set oNextSection = ActiveDocument.Sections(lsectionno + 1)
          oNextSection.Headers(WdHeaderFooterIndex.wdHeaderFooterPrimary).LinkToPrevious = bLinkToPrevious
          oNextSection.Footers(WdHeaderFooterIndex.wdHeaderFooterPrimary).LinkToPrevious = bLinkToPrevious
      End If
      oCurrentSection.Headers(WdHeaderFooterIndex.wdHeaderFooterPrimary).LinkToPrevious = bLinkToPrevious
      oCurrentSection.Footers(WdHeaderFooterIndex.wdHeaderFooterPrimary).LinkToPrevious = bLinkToPrevious
      oCurrentSection.PageSetup.Orientation = WdOrientation.wdOrientLandscape
'always reset these, regardless of linktoprevious or not
      Set oHeaderRange = oCurrentSection.Headers(WdHeaderFooterIndex.wdHeaderFooterPrimary).Range
      oHeaderRange.ParagraphFormat.TabStops.Item(1).Position = CentimetersToPoints(25.75)
      Set oFooterRange = oCurrentSection.Footers(WdHeaderFooterIndex.wdHeaderFooterPrimary).Range
      oFooterRange.ParagraphFormat.TabStops.Item(1).Position = CentimetersToPoints(8.5)
      oFooterRange.ParagraphFormat.TabStops.Item(2).Position = CentimetersToPoints(25.75)
   End If
   Set oNextSection = Nothing
   Set oHeaderRange = Nothing
   Set oFooterRange = Nothing
   Set oCurrentSection = Nothing
End Sub

Public Sub Layout_InsertPortraitPage() 
Dim lsectionno As Long
Dim oCurrentSection As Section
Dim oPreviousSection As Section
Dim oRange As Range

   lsectionno = Selection.Information(wdActiveEndSectionNumber)
   Set oCurrentSection = ActiveDocument.Sections(lsectionno)
   If (oCurrentSection.PageSetup.Orientation = wdOrientPortrait) Then
      Exit Sub
   End If
   Set oCurrentSection = Selection.Sections(1)
   Selection.MoveUp wdLine, 1
   Set oPreviousSection = Selection.Sections(1)
   Selection.MoveDown wdLine, 1
   If (oPreviousSection.Index = oCurrentSection.Index) Then
      Selection.TypeParagraph
      Selection.InsertBreak (wdSectionBreakNextPage)
      With Selection
          .TypeParagraph
          Set oRange = Selection.Range
          oRange.MoveStart wdParagraph, -1
          oRange.Select
          .Style = ActiveDocument.Styles("Heading 1")
          .TypeText "New Portrait Section"
          Set oRange = Selection.Range
          oRange.MoveStart wdParagraph, 1
          oRange.Select
          If (Selection_IsAtEndOfDocument = False) Then
             .TypeParagraph
             .TypeParagraph
             .InsertBreak (wdSectionBreakNextPage)
             .Delete
             Set oRange = Selection.Range
             oRange.Move wdParagraph, -3
             oRange.Select
          End If
          Call Layout_SwitchToPortraitSection(True)
      End With
   Else
   End If
   Set oRange = Nothing
   Set oCurrentSection = Nothing
End Sub

Public Sub Layout_SwitchToPortraitSection(ByVal bLinkToPrevious As Boolean) 
Dim lsectionno As Long
Dim ipageno As Integer
Dim oCurrentSection As Section
Dim oNextSection As Section
Dim oHeaderRange As Range
Dim oFooterRange As Range

   lsectionno = Selection.Information(wdActiveEndSectionNumber)
   Set oCurrentSection = ActiveDocument.Sections(lsectionno)
   If (oCurrentSection.PageSetup.Orientation = wdOrientPortrait) Then
   Else
      If (ActiveDocument.Sections.Count > lsectionno) Then
          Set oNextSection = ActiveDocument.Sections(lsectionno + 1)
          oNextSection.Headers(wdHeaderFooterPrimary).LinkToPrevious = bLinkToPrevious
          oNextSection.Footers(wdHeaderFooterPrimary).LinkToPrevious = bLinkToPrevious
      End If
      oCurrentSection.Headers(wdHeaderFooterPrimary).LinkToPrevious = bLinkToPrevious
      oCurrentSection.Footers(wdHeaderFooterPrimary).LinkToPrevious = bLinkToPrevious
      oCurrentSection.PageSetup.Orientation = wdOrientPortrait
      If (bLinkToPrevious = False) Then
         Set oHeaderRange = oCurrentSection.Headers(wdHeaderFooterPrimary).Range
         oHeaderRange.ParagraphFormat.TabStops.Item(1).Position = CentimetersToPoints(17)
         Set oFooterRange = oCurrentSection.Footers(wdHeaderFooterPrimary).Range
         oFooterRange.ParagraphFormat.TabStops.Item(1).Position = CentimetersToPoints(8.5)
         oFooterRange.ParagraphFormat.TabStops.Item(2).Position = CentimetersToPoints(17)
      End If
   End If
   Set oNextSection = Nothing
   Set oHeaderRange = Nothing
   Set oFooterRange = Nothing
   Set oCurrentSection = Nothing
End Sub

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