페이지, 페이지 요소, 속성

Slides API를 효과적으로 사용하려면 프레젠테이션의 아키텍처와 구성요소와 이러한 구성요소 간의 상호작용을 이해해야 합니다. 이 페이지에서는 이러한 주제를 자세히 설명합니다.

  • 프레젠테이션 구성요소의 개념적 모델
  • API가 구성요소를 나타내는 방식
  • 구성요소의 스타일 지정 속성

이 개요와 기타 개념 개요를 읽으면 안내 가이드, 참조 문서, 레시피 샘플을 더 쉽게 이해하고 사용할 수 있습니다.

프레젠테이션, 페이지, 페이지 요소

Google Slides에서 가장 바깥쪽 컨테이너 요소는 프레젠테이션입니다. Google Drive에 저장하고 다른 사용자와 공유할 수 있는 단원입니다.

각 프레젠테이션에는 다양한 유형의 페이지가 포함되어 있습니다. 페이지의 한 가지 유형은 슬라이드로, 슬라이드는 화면에서 프레젠테이션이 렌더링될 때 사용자가 보고 넘기는 페이지입니다.

각 페이지에는 다음 다이어그램과 같이 페이지의 콘텐츠를 구성하는 여러 페이지 요소가 포함됩니다.

Slides 아키텍처 다이어그램

슬라이드 외에도 다양한 슬라이드에 디자인을 적용하여 일관된 모양을 만들 수 있는 다른 페이지 유형이 있습니다. 이러한 기타 페이지 유형은 마스터레이아웃이며 해당 속성은 다음 다이어그램과 같이 슬라이드 렌더링 방식을 결정합니다.

테마 아키텍처 다이어그램

마스터 — 마스터 페이지의 용도는 두 가지입니다. 마스터의 자리표시자에는 프레젠테이션 전체에서 사용되는 텍스트 스타일의 기본값이 포함됩니다. 마스터 슬라이드의 배경 및 기타 도형은 해당 마스터를 기반으로 하는 모든 슬라이드의 기본 배경을 구성합니다. 프레젠테이션의 모든 슬라이드에 회사 로고를 표시하려면 해당 로고를 마스터에 배치하세요.

레이아웃 — 레이아웃 템플릿은 각 유형의 슬라이드에 콘텐츠를 정렬하는 방식을 결정합니다. 예를 들어 모든 제목 슬라이드를 특정 방식으로 표시하려면 제목 레이아웃 템플릿을 수정하면 됩니다.

노트 마스터와 노트 마스터라는 두 가지 종류의 페이지가 더 있는데, 주로 발표자 노트를 다루는 데 적합합니다.

API 표현 유형 및 구조

이 섹션에서는 위에서 설명한 대로 Google Slides 개념 모델이 Slides API에서 어떻게 표현되는지 설명합니다.

다음 다이어그램은 Slides API에서 프레젠테이션, 페이지, 페이지 요소 간의 관계를 유형으로 보여줍니다.

erd 스타일 다이어그램

다음 섹션에서는 이러한 유형이 JSON에서 어떻게 표시되는지 보여줍니다.

프레젠테이션

프레젠테이션에는 여러 속성과 함께 그 내용이 포함되어 있습니다.

{
  "presentationId": string,
  "pageSize": { object(Size) },
  "slides": [ { object(Page) } ],
  "title": string,
  "masters": [ { object(Page) } ],
  "layouts": [ { object(Page) } ],
  "notesMaster": object(Page),
  "locale": string,
}

페이지

페이지는 속성 집합과 함께 다음과 같은 페이지 요소를 포함합니다.

{
  "objectId": string,
  "pageType": enum(PageType),
  "pageElements": [ { object(PageElement) } ],
  "pageProperties": { object(PageProperties) },

  // Union field properties can be only one of the following:
  "slideProperties": { object(SlideProperties) },
  "layoutProperties": { object(LayoutProperties) },
  "notesProperties": { object(NotesProperties) },
  // End of list of possible types for union field properties.
}

페이지 요소

페이지 요소는 페이지에 배치되는 시각적 구성요소입니다. API의 페이지 요소에는 페이지 요소의 종류에 따라 달라지는 필드를 비롯한 여러 속성이 포함됩니다.

{
  "objectId": string,
  "size": { object(Size) },
  "transform": { object(AffineTransform) },
  "title": string,
  "description": string,

  // Union field element_kind can be only one of the following:
  "elementGroup": { object(Group) },
  "shape": { object(Shape) },
  "image": { object(Image) },
  "video": { object(Video) },
  "line": { object(Line) },
  "table": { object(Table) },
  "wordArt": { object(WordArt) },
  "sheetsChart": { object(SheetsChart) },
  // End of list of possible types for union field element_kind.
}

위 정의에서 공용체 필드 element_kind로 정의된 여러 종류의 페이지 요소가 있습니다. 이러한 종류의 페이지 요소는 다음 표에 설명되어 있습니다.

요소 종류 설명
그룹 개별 단위로 취급되는 페이지 요소의 집합입니다. 함께 이동, 크기 조정, 회전할 수 있습니다.
모양 직사각형, 타원형, 텍스트 상자와 같은 일반적인 시각적 객체 도형은 텍스트를 포함할 수 있으므로 슬라이드를 만드는 데 가장 일반적인 페이지 요소입니다.
이미지 Slides로 가져온 그래픽
동영상 Slides로 가져온 동영상
시각적 선, 곡선 또는 연결선
테이블 콘텐츠 그리드입니다.
WordArt 도형처럼 동작하는 시각적 텍스트 요소
SheetsChart Google Sheets에서 Slides로 가져온 차트

페이지 및 페이지 요소 속성

Slides API를 사용하면 프레젠테이션에서 페이지 및 페이지 요소의 모양을 읽고 업데이트할 수 있습니다. 페이지 요소마다 페이지 요소가 렌더링되는 방식을 제어하는 서로 다른 속성을 지원합니다.

각 페이지 요소 종류에는 해당하는 속성 요소와 속성 업데이트 메시지가 있습니다. 예를 들면 다음과 같습니다.

각 페이지 요소 유형(Image/imageProperties/UpdateImageProperties 등)에 동일한 요소/속성/업데이트 요청 집합이 존재합니다.

요소를 읽을 때 속성이 있는 곳마다 속성 속성을 읽을 수 있습니다. 속성의 값을 변경하려면 일치하는 요청 유형과 함께 batchUpdate 메서드의 페이로드로 이 속성을 사용하여 프레젠테이션에서 값을 변경할 수 있습니다.

속성의 종류

Slides API에는 여러 종류의 객체 간에 공통된 몇 가지 속성이 있습니다.

속성 설명
색상 Slides API의 색상은 RGB 값이거나 테마 색상 참조일 수 있습니다. 테마 색상은 이름 (예: 'DARK1')으로 참조되며 페이지의 색 구성표를 사용하여 RGB 값에 매핑할 수 있습니다. 이 색 구성표는 일반적으로 Slides 편집기에서 프레젠테이션의 테마를 변경할 때 업데이트됩니다.
채우기 채우기는 객체 내 빈 공간의 렌더링을 나타냅니다. Slides에서 가장 일반적으로 지원되는 채우기는 객체의 내부가 단일 단색으로 채워지는 단색 채우기입니다. 채우기는 페이지 배경으로도 사용할 수 있습니다.
윤곽선 윤곽선은 페이지 요소를 둘러싼 선 집합을 나타냅니다. 선의 색상은 채우기로 제어할 수 있습니다. 호출자는 윤곽선의 너비와 대시 스타일을 조정할 수도 있습니다.
그림자 그림자는 객체가 드리우는 물리적 그림자를 모방하기 위한 시각적 효과를 나타냅니다. 현재 Slides API의 그림자는 읽기 전용입니다.

숙박 시설 업데이트

속성을 업데이트하려면 batchUpdate 호출에서 적절한 Update...Properties 요청을 사용합니다(예: 도형의 경우 UpdateShapeProperties). 이러한 요청은 전체 속성 메시지를 수락하며 필드 마스크를 사용하여 속성 메시지에서 업데이트해야 할 필드를 결정할 수 있습니다.

속성 상속

페이지 또는 페이지 요소는 상위 객체에서 속성을 상속할 수 있습니다. 객체의 속성(정의된 속성과 상속한 속성 포함)에 따라 시각적 모양이 결정됩니다.

  • 페이지 속성 - 페이지는 페이지가 정의하지 않았지만 페이지가 기반으로 하는 레이아웃 또는 마스터에 정의된 속성을 상속합니다.
  • 도형 속성 - 도형을 자리표시자로 표시하여 속성을 상속받을 (페이지의 상위 레이아웃 또는 마스터에서) 다른 자리표시자 도형을 명시적으로 참조할 수 있습니다.

이러한 개념은 다음 단락에서 자세히 설명합니다.

페이지 속성 상속

슬라이드, 레이아웃, 마스터의 구조는 프레젠테이션 내에서 상속 계층 구조를 정의합니다. 즉, 슬라이드는 레이아웃에서 상속되고 레이아웃은 마스터에서 상속됩니다. 슬라이드의 상위 레이아웃 및 마스터는 슬라이드의 slideProperties 필드에서 지정됩니다.

페이지는 상위 페이지에서 배경색 구성표와 같은 속성을 상속할 수 있습니다. 속성을 상속받기 위해 하위 페이지는 PageProperties 메시지에 해당 속성의 값을 설정하지 않습니다. 상위 요소가 정의한 값을 '재정의'하지 않으면 페이지에서 상속된 값을 허용합니다.

다음 다이어그램은 레이아웃에서 속성을 상속하고 마스터에서 속성을 상속하는 슬라이드를 보여줍니다.

슬라이드 속성 상속

슬라이드를 렌더링하는 데 사용되는 속성은 슬라이드가 정의한 속성과 상속한 속성의 조합입니다. 이 예에서 슬라이드 1을 렌더링하는 데 사용되는 결정된 값은 다음과 같습니다.

  • PropertyA는 "Red"입니다.
  • PropertyB는 "Orange"입니다.

도형 속성 상속

도형은 다른 도형에서 채우기, 윤곽선 또는 그림자와 같은 속성을 상속할 수 있습니다. 도형은 Shape.placeholder 필드가 설정된 경우 자리표시자입니다. 하위 자리표시자의 Shape.placeholder.parentObjectId 필드는 상위 자리표시자를 식별합니다. 레이아웃을 기반으로 새 슬라이드를 만드는 경우 해당 레이아웃의 모든 자리표시자는 새 슬라이드에서 하위 도형으로 표시됩니다. 마찬가지로 마스터 페이지의 자리표시자는 레이아웃 자리표시자의 상위 요소 역할을 할 수 있습니다.

이 상속 계층 구조를 정의하면 하위 페이지는 ShapeProperties 메시지에 해당 값을 설정하지 않고 속성을 상속합니다. 상위 요소에서 정의한 값을 재정의하지 않으면 자식 도형이 상속된 값을 수락합니다.

다음 다이어그램은 슬라이드, 레이아웃, 마스터에 포함된 세 가지 자리표시자 간 속성 상속을 보여줍니다.

도형 속성 상속

자리표시자 도형을 렌더링하는 데 사용되는 속성은 도형이 정의한 속성과 상속한 속성의 조합입니다. 이 예에서 이러한 도형에 대해 결정된 값은 다음과 같습니다.

  • 자리표시자 1: propertyA는 'Yellow'로, propertyB는 'Green'으로 렌더링됩니다.
  • 자리표시자 2: propertyA는 'Yellow'로, propertyB는 'Purple'로 렌더링됩니다.
  • 자리표시자 3: propertyA는 'Yellow'로, propertyB는 'Purple'로 렌더링됩니다.

도형은 상위 요소를 가질 수 있는 유일한 페이지 요소 유형입니다. 이미지, 표, 차트와 같은 다른 유형은 자리표시자가 될 수 없으며 상위 요소를 포함할 수 없습니다.

PropertyState를 사용하여 속성 '숨기기'

PropertyState 열거형은 도형의 속성이 실제로 렌더링에 사용되는지, 아니면 값이 하위 도형의 상속에만 사용되는지 제어합니다. 속성 상태가 NOT_RENDERED인 속성은 페이지에 도형을 렌더링할 때 사용되지 않지만 상응하는 속성 상태가 RENDERED인 하위 요소는 여전히 이 속성을 상속할 수 있습니다.

다음 다이어그램은 PropertyState 필드를 조작하는 세 자리표시자 간 속성 상속을 보여줍니다.

속성 상태 및 상속

도형 속성의 렌더링은 PropertyState 필드의 영향을 받을 수 있습니다. 이 예에서 이러한 도형에 대해 결정된 값은 다음과 같습니다.

  • 자리표시자 1: propertyA는 'Red'로 렌더링됩니다.
  • 자리표시자 2: propertyA는 렌더링되지 않습니다. 윤곽선 속성인 경우 Placeholder2에는 윤곽선이 없습니다.
  • Placeholder3: propertyA는 렌더링되지 않습니다.

PropertyState 열거형에는 가능한 값이 하나 더 있습니다. INHERIT 속성 상태는 속성 상태 자체가 상속되며 상위 요소의 값을 사용해야 함을 의미합니다. 상위 요소가 없는 도형은 속성 상태가 INHERIT일 수 없습니다.