Slides API를 효과적으로 사용하려면 프레젠테이션과 그 구성요소의 아키텍처는 물론 이러한 구성요소 간의 상호작용을 이해해야 합니다. 이 페이지에서는 다음 주제를 자세히 설명합니다.
- 프레젠테이션 구성요소의 개념 모델
- API에서 이러한 구성요소를 표현하는 방식
- 구성요소의 스타일 속성
이 개요와 다른 개념 개요를 읽으면 안내 가이드, 참조 문서, 레시피 샘플을 더 쉽게 이해하고 사용할 수 있습니다.
프레젠테이션, 페이지, 페이지 요소
Google Slides의 가장 바깥쪽 컨테이너 요소는 프레젠테이션입니다. 이것은 Google Drive에 저장하고 다른 사용자와 공유할 수 있는 단위입니다.
각 프레젠테이션에는 다양한 유형의 페이지가 포함되어 있습니다. 한 유형의 페이지는 슬라이드입니다. 슬라이드는 프레젠테이션이 화면에 렌더링될 때 사용자가 보고 전환하는 페이지입니다.
각 페이지에는 여러 페이지 요소가 포함되어 있으며, 이러한 요소가 함께 페이지의 콘텐츠를 구성합니다.

슬라이드 외에도 여러 슬라이드에 디자인을 적용하여 일관된 모양을 만들 수 있는 다른 유형의 페이지가 있습니다. 이러한 다른 페이지 유형은 마스터와 레이아웃이며, 이러한 페이지 유형의 속성은 다음 다이어그램에 표시된 것처럼 슬라이드가 렌더링되는 방식을 결정합니다.

마스터 - 마스터 페이지는 두 가지 용도로 사용됩니다. 마스터의 자리표시자에는 프레젠테이션 전체에서 사용되는 텍스트 스타일의 기본값이 포함되어 있습니다. 마스터 슬라이드의 배경과 기타 도형은 해당 마스터를 기반으로 하는 모든 슬라이드의 기본 배경을 구성합니다. 프레젠테이션의 모든 슬라이드에 표시할 회사 로고가 있는 경우 마스터에 넣습니다.
레이아웃 - 레이아웃 템플릿은 각 유형의 슬라이드에 콘텐츠가 배치되는 방식을 결정합니다. 모든 제목 슬라이드가 특정 방식으로 표시되도록 하려면 제목 레이아웃 템플릿을 수정하면 됩니다.
발표자 메모 작업과 주로 관련된 두 가지 종류의 페이지(메모 페이지 및 메모 마스터)도 있습니다.
API 표현 유형 및 구조
이 섹션에서는 위에서 설명한 Google Slides 개념 모델이 Slides API에서 어떻게 표현되는지 설명합니다.
다음 다이어그램은 Slides API의 유형으로서 프레젠테이션, 페이지, 페이지 요소 간의 관계를 보여줍니다.

다음 섹션에서는 이러한 유형이 JSON으로 표현되는 방법을 보여줍니다.
프레젠테이션
프레젠테이션에는 여러 속성이 포함되어 있으며 프레젠테이션에 포함된 페이지가 포함되어 있습니다.
{
"presentationId": string,
"pageSize": { object(Size) },
"slides": [ { object(Page) } ],
"title": string,
"masters": [ { object(Page) } ],
"layouts": [ { object(Page) } ],
"notesMaster": object(Page),
"locale": string,
}
Pages
페이지에는 속성 집합이 포함되며 페이지에 있는 페이지 요소가 포함됩니다.
{
"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로 가져온 동영상 |
| 선 | 시각적 선, 곡선 또는 커넥터입니다. |
| 표 | 콘텐츠 그리드입니다. |
| WordArt | 모양과 더 유사하게 작동하는 시각적 텍스트 요소입니다. |
| SheetsChart | Google Sheets에서 슬라이드로 가져온 차트 |
페이지 및 페이지 요소 속성
Slides API를 사용하면 프레젠테이션의 페이지와 페이지 요소의 모양을 읽고 업데이트할 수 있습니다. 다양한 페이지 요소는 페이지 요소가 렌더링되는 방식을 제어하는 다양한 속성을 지원합니다.
각 페이지 요소 종류에는 해당하는 속성 요소와 속성 업데이트 메시지가 있습니다. 예를 들면 다음과 같습니다.
- 도형이라는 페이지 요소 유형이 있습니다.
- 속성 필드는 shapeProperties입니다.
- 이러한 속성을 업데이트하는 요청은 UpdateShapePropertiesRequest입니다.
각 페이지 요소 유형(이미지/imageProperties/UpdateImageProperties 등)에 동일한 요소/속성/업데이트 요청이 있습니다.
요소를 읽을 때 속성 속성을 발견하는 곳 어디에서나 읽을 수 있습니다. 속성 속성의 값을 변경하려면 일치하는 요청 유형과 함께 batchUpdate 메서드의 페이로드로 사용하여 프레젠테이션에서 이러한 값을 변경할 수 있습니다.
속성 종류
프레젠테이션 API의 여러 종류의 객체 간에 공통적인 속성이 있습니다.
| 속성 | 설명 |
|---|---|
| 색상 | Slides API의 색상은 RGB 값 또는 테마 색상에 대한 참조일 수 있습니다. 테마 색상은 이름 (예: 'DARK1')으로 참조되며 페이지의 색 구성표를 사용하여 RGB 값에 매핑할 수 있습니다. 이 색 구성표는 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에는 윤곽선이 없습니다.
- 자리표시자3: propertyA가 렌더링되지 않습니다.
PropertyState 열거형에는 또 다른 가능한 값이 있습니다. INHERIT 속성 상태는 속성 상태 자체가 상속되었으며 상위 요소의 값을 사용해야 함을 의미합니다. 상위 요소가 없는 도형은 INHERIT 속성 상태를 가질 수 없습니다.