Google Slides API की मदद से, PageElement
संसाधन बनाए जा सकते हैं और उनमें बदलाव किया जा सकता है. इनमें टेक्स्ट बॉक्स, इमेज, टेबल, सामान्य आकार, लाइनें, और एम्बेड किए गए वीडियो शामिल हैं. इस पेज पर दिए गए उदाहरणों में, presentations.batchUpdate
तरीके का इस्तेमाल करके, पेज एलिमेंट पर होने वाली कुछ सामान्य कार्रवाइयां दिखाई गई हैं.
इन उदाहरणों में इन वैरिएबल का इस्तेमाल किया गया है:
- PRESENTATION_ID—इससे पता चलता है कि आपने प्रज़ेंटेशन आईडी कहां सबमिट किया है. प्रेज़ेंटेशन के यूआरएल से, इस आईडी की वैल्यू वापस पाई जा सकती है.
- PAGE_ID—इससे पता चलता है कि आपने पेज ऑब्जेक्ट आईडी कहां दिया है. इसके लिए यूआरएल से या एपीआई पढ़ने के अनुरोध का इस्तेमाल करके, वैल्यू फिर से हासिल की जा सकती है.
- PAGE_ELEMENT_ID—इससे पता चलता है कि आपने पेज एलिमेंट ऑब्जेक्ट आईडी कहां दिया है. इस आईडी को अपने बनाए गए एलिमेंट (कुछ पाबंदियों के साथ) के लिए तय किया जा सकता है या Slides API को अपने-आप इसे बनाने की अनुमति दी जा सकती है. एलिमेंट आईडी को एपीआई पढ़ने के अनुरोध की मदद से फिर से पाया जा सकता है.
ये उदाहरण भाषा न्यूट्रल होने के एचटीटीपी अनुरोधों के तौर पर दिखाए गए हैं. Google API क्लाइंट लाइब्रेरी का इस्तेमाल करके, बैच अपडेट को अलग-अलग भाषाओं में लागू करने का तरीका जानने के लिए, नीचे दी गई गाइड देखें:
टेक्स्ट बॉक्स में बुलेट वाली सूची जोड़ना
यहां दिए गए presentations.batchUpdate
कोड सैंपल में, InsertTextRequest
वाले तरीके का इस्तेमाल करके PAGE_ELEMENT_ID के बताए गए खाली टेक्स्ट बॉक्स में टेक्स्ट डालने का तरीका बताया गया है. इसके बाद, यह सैंपल टेक्स्ट बॉक्स के सभी टेक्स्ट को बुलेट वाली सूची में बदलने के लिए, CreateParagraphBulletsRequest
वाले तरीके का इस्तेमाल करता है. सूची के आइटम
को \n
वर्णों से अलग किया जाता है, जबकि इंडेंट को \t
वर्णों से कंट्रोल किया जाता है.
प्रज़ेंटेशन बनाने के लिए अनुरोध प्रोटोकॉल यहां दिया गया है:
POST https://slides.googleapis.com/v1/presentations/PRESENTATION_ID:batchUpdate
{ "requests": [ { "insertText": { "objectId": PAGE_ELEMENT_ID, "text": "My List\n\tItem 1\n\t\tItem 2\n\t\t\tItem 3", "insertionIndex": 0 }, "createParagraphBullets": { "objectId": PAGE_ELEMENT_ID, "bulletPreset": "BULLET_ARROW_DIAMOND_DISC", "textRange": { "type": "ALL" } } } ] }
इस अनुरोध से बुलेट वाली सूची बनाई जा सकती है, जो इस तरह दिखती है:
किसी स्लाइड में कोई आकार जोड़ें
नीचे दिया गया
presentations.batchUpdate
कोड सैंपल, CreateShapeRequest
तरीके का इस्तेमाल करके, PAGE_ID के बताए गए किसी स्लाइड में वेव शेप जोड़ने का तरीका बताता है.
यह अनुरोध, आकार के टाइप के बारे में बताता है और फिर स्लाइड में आकार को फ़िट करके दिखाता है. इसके बाद, यह उस आकार में टेक्स्ट जोड़ने के लिए, InsertTextRequest
तरीके का इस्तेमाल करता है. अनुरोध, लाइन के आईडी को
PAGE_ELEMENT_ID पर सेट करता है.
किसी स्लाइड में आकार जोड़ने के लिए, अनुरोध प्रोटोकॉल यहां दिया गया है:
POST https://slides.googleapis.com/v1/presentations/PRESENTATION_ID:batchUpdate
{ "requests": [ { "createShape": { "objectId": PAGE_ELEMENT_ID, "elementProperties": { "pageObjectId": PAGE_ID, "size": { "width": { "magnitude": 3000000, "unit": "EMU" }, "height": { "magnitude": 3000000, "unit": "EMU" } }, "transform": { "scaleX": 0.6807, "scaleY": 0.4585, "translateX": 6583050, "translateY": 1673950, "unit": "EMU" } }, "shapeType": "WAVE" } }, { "insertText": { "objectId": PAGE_ELEMENT_ID, "text": "My Wave Shape", "insertionIndex": 0 } } ] }
किसी स्लाइड में वीडियो जोड़ना
यहां दिया गया presentations.batchUpdate
कोड सैंपल CreateVideoRequest
तरीके का इस्तेमाल करके, PAGE_ID के बताए गए किसी स्लाइड में वीडियो को एम्बेड करने का तरीका बताता है.
यह अनुरोध, स्लाइड में वीडियो को स्केल और पोज़िशन करता है. साथ ही, वीडियो के आईडी को PAGE_ELEMENT_ID पर सेट करता है. सोर्स वीडियो के यूनीक आइडेंटिफ़ायर को VIDEO_ID पर सेट किया गया है. उदाहरण के लिए, https://www.youtube.com/watch?v=7U3axjORYZ0
पर मौजूद YouTube वीडियो का आईडी 7U3axjORYZ0
है.
किसी स्लाइड में वीडियो जोड़ने के लिए, अनुरोध का प्रोटोकॉल यहां दिया गया है:
POST https://slides.googleapis.com/v1/presentations/PRESENTATION_ID:batchUpdate
{ "requests": [ { "createVideo": { "objectId": PAGE_ELEMENT_ID, "elementProperties": { "pageObjectId": PAGE_ID, "size": { "width": { "magnitude": 12000, "unit": "EMU" }, "height": { "magnitude": 9000, "unit": "EMU" } }, "transform": { "scaleX": 381, "scaleY": 381, "translateX": 152400, "translateY": 152400, "unit": "EMU" } }, "source": "YOUTUBE", "id": VIDEO_ID } } ] }
किसी एलिमेंट को कॉपी करना और उसमें बदलाव करना
यहां दिए गए presentations.batchUpdate
कोड सैंपल में, DuplicateObjectRequest
तरीके का इस्तेमाल करके, कोई मौजूदा आकार (PAGE_ELEMENT_ID में बताया गया है) लेने और उसकी कॉपी बनाने (COPY_ELEMENT_ID में बताया गया है) करने का तरीका बताया गया है.
बाद में किए जाने वाले अनुरोध, डुप्लीकेट ऑब्जेक्ट में ये बदलाव करते हैं:
- बैकग्राउंड के रंग को
LIGHT2
थीम के रंग पर सेट करता है. - कॉपी को पेज पर नीचे की ओर ले जाता है (मूल आकार की जगह से).
- टेक्स्ट के फ़ॉन्ट को 18-पॉइंट जॉर्जिया पर सेट करता है.
- "मेरा आकार कॉपी" पढ़ने के लिए टेक्स्ट में बदलाव करता है.
यहां किए गए अनुरोध, उन आकार प्रॉपर्टी को बनाए रखने के लिए फ़ील्ड मास्क का इस्तेमाल करते हैं जिनमें बदलाव नहीं किए जाते हैं (जैसे कि आउटलाइन स्टाइल). फ़ील्ड मास्क का इस्तेमाल करने से भी परफ़ॉर्मेंस बेहतर होती है.
स्लाइड कॉपी करने के बारे में ज़्यादा जानकारी के लिए, स्लाइड कॉपी करना का नमूना देखें.
किसी एलिमेंट को कॉपी करके उसमें बदलाव करने के लिए, अनुरोध का प्रोटोकॉल यहां दिया गया है:
POST https://slides.googleapis.com/v1/presentations/PRESENTATION_ID:batchUpdate
{ "requests": [ { "duplicateObject": { "objectId": PAGE_ELEMENT_ID, "objectIds": { PAGE_ELEMENT_ID: COPY_ELEMENT_ID } } }, { "updateShapeProperties": { "objectId": COPY_ELEMENT_ID, "fields": "shapeBackgroundFill.solidFill.color", "shapeProperties": { "shapeBackgroundFill": { "solidFill": { "color": { "themeColor": "LIGHT2" } } } } } }, { "updatePageElementTransform": { "objectId": COPY_ELEMENT_ID, "applyMode": "RELATIVE", "transform": { "scaleX": 1, "scaleY": 1, "translateX": 0, "translateY": 1250000, "unit": "EMU" } } }, { "updateTextStyle": { "objectId": COPY_ELEMENT_ID, "fields": "fontFamily,fontSize", "textRange": { "type": "ALL" }, "style": { "fontFamily": "Georgia", "fontSize": { "magnitude": 18, "unit": "PT" } } } }, { "deleteText": { "objectId": COPY_ELEMENT_ID, "textRange": { "type": "ALL" } } }, { "insertText": { "objectId": COPY_ELEMENT_ID, "text": "My Shape Copy", "insertionIndex": 0 } } ] }
यहां बताया गया है कि इन अपडेट के बाद कोई आकृति और उसकी कॉपी कैसी दिख सकती है:
किसी इमेज या वीडियो की आउटलाइन में बदलाव करना
यहां दिए गए कोड सैंपल presentations.batchUpdate
में UpdateImagePropertiesRequest
तरीके का इस्तेमाल करके IMAGE_ELEMENT_ID की मदद से तय की गई इमेज के दिखने के तरीके को अपडेट करने का तरीका बताया गया है. इसमें UpdateVideoPropertiesRequest
तरीके का इस्तेमाल करके, एम्बेड किए गए वीडियो की आउटलाइन को अपडेट भी किया जाता है. यह बदलाव, VIDEO_ELEMENT_ID में बताया जाता है.
अनुरोध, ऑब्जेक्ट में ये बदलाव करते हैं:
- यह नीति, इमेज की आउटलाइन के रंग को
ACCENT5
थीम के रंग पर सेट करती है. साथ ही, यह कुछ हद तक पारदर्शिता के साथ सेट करती है. - यह विकल्प, वीडियो के आउटलाइन के रंग को
ACCENT1
थीम के रंग पर सेट करता है. साथ ही, यह बिना किसी पारदर्शिता के सेट करता है. - दोनों के लिए आउटलाइन का वज़न 3-पॉइंट सेट करता है.
- इमेज की आउटलाइन की स्टाइल को
SOLID
पर सेट करता है. - वीडियो की आउटलाइन की स्टाइल को
DASH_DOT
पर सेट करता है.
UpdateImagePropertiesRequest
तरीके और UpdateVideoPropertiesRequest
तरीके, दोनों से सिर्फ़ इमेज और वीडियो की आउटलाइन में बदलाव किया जा सकता है. अन्य सभी प्रॉपर्टी रीड-ओनली होती हैं. यहां किए गए अनुरोध, फ़ील्ड मास्क का इस्तेमाल करके यह बताते हैं कि सिर्फ़ आउटलाइन को बदला जाना चाहिए, ताकि आने वाले समय में एपीआई में होने वाले बदलावों से कोड को सुरक्षित रखा जा सके. फ़ील्ड मास्क का इस्तेमाल करने से भी परफ़ॉर्मेंस बेहतर होती है.
किसी इमेज या वीडियो की आउटलाइन में बदलाव करने के लिए, अनुरोध का प्रोटोकॉल यहां दिया गया है:
POST https://slides.googleapis.com/v1/presentations/PRESENTATION_ID:batchUpdate
{ "requests": [ { "updateImageProperties": { "objectId": IMAGE_ELEMENT_ID, "fields": "outline", "imageProperties": { "outline": { "dashStyle": "SOLID", "outlineFill": { "solidFill": { "alpha": 0.8, "color": { "themeColor": "ACCENT5" } } }, "weight": { "magnitude": 3, "unit": "PT" } } } } }, { "updateVideoProperties": { "objectId": VIDEO_ELEMENT_ID, "fields": "outline", "videoProperties": { "outline": { "dashStyle": "DASH_DOT", "outlineFill": { "solidFill": { "alpha": 0.8, "color": { "themeColor": "ACCENT1" } } }, "weight": { "magnitude": 3, "unit": "PT" } } } } } ] }
यहां बताया गया है कि इन अपडेट के बाद कोई इमेज और एम्बेड किया गया वीडियो कैसा दिखेगा:
आकार की आउटलाइन में बदलाव करना
यहां दिए गए presentations.batchUpdate
कोड सैंपल में, UpdateShapePropertiesRequest
तरीके का इस्तेमाल करके, कोई मौजूदा आकार (PAGE_ELEMENT_ID में बताया गया है) लेने का तरीका बताया गया है. साथ ही, इसकी आउटलाइन को अपडेट करने का तरीका भी बताया गया है.
अनुरोध, ऑब्जेक्ट में ये बदलाव करते हैं:
- यह नीति, कुछ हद तक पारदर्शिता के साथ
ACCENT5
थीम के रंग पर आउटलाइन का रंग सेट करती है. - आउटलाइन का वज़न 3-पॉइंट पर सेट करता है.
- आउटलाइन स्टाइल को
LONG_DASH
पर सेट करता है.
यहां किए गए अनुरोध, आकार की उन प्रॉपर्टी को सुरक्षित रखने के लिए फ़ील्ड मास्क का इस्तेमाल करते हैं जिन्हें नहीं बदला जाता है. जैसे, आकार में भरने का रंग. फ़ील्ड मास्क का इस्तेमाल करने से भी परफ़ॉर्मेंस बेहतर होती है.
किसी आकार की आउटलाइन में बदलाव करने के लिए, अनुरोध प्रोटोकॉल यहां दिया गया है:
POST https://slides.googleapis.com/v1/presentations/PRESENTATION_ID:batchUpdate
{ "requests": [ { "updateShapeProperties": { "objectId": PAGE_ELEMENT_ID, "fields": "outline", "shapeProperties": { "outline": { "dashStyle": "LONG_DASH", "outlineFill": { "solidFill": { "alpha": 0.6, "color": { "themeColor": "ACCENT5" } } }, "weight": { "magnitude": 3, "unit": "PT" } } } } } ] }
यहां बताया गया है कि इन अपडेट के बाद कोई आकृति कैसी दिखेगी:
टेक्स्ट को आकार या टेक्स्ट बॉक्स में फ़ॉर्मैट करना
यहां दिया गया
presentations.batchUpdate
कोड सैंपल, UpdateTextStyleRequest
तरीके का इस्तेमाल करके, किसी मौजूदा आकार (PAGE_ELEMENT_ID में बताया गया) को लेने के तरीके के बारे में बताता है और टेक्स्ट के दिखने के तरीके को अपडेट करता है.
अनुरोध, ऑब्जेक्ट में ये बदलाव करते हैं:
- टेक्स्ट के रंग को
ACCENT5
थीम के रंग पर सेट करता है. - फ़ॉन्ट को बोल्ड, इटैलिक 18-pt Corsiva पर सेट करता है.
- टेक्स्ट को अंडरलाइन करता है.
यहां किए गए अनुरोध, टेक्स्ट स्टाइल की उन प्रॉपर्टी को बनाए रखने के लिए फ़ील्ड मास्क का इस्तेमाल करते हैं जिन्हें नहीं बदला गया है. जैसे, बैकग्राउंड का रंग, लिंक या बेसलाइन ऑफ़सेट. फ़ील्ड मास्क का इस्तेमाल करने से भी परफ़ॉर्मेंस बेहतर होती है.
किसी आकार या टेक्स्ट बॉक्स में टेक्स्ट को फ़ॉर्मैट करने के लिए, अनुरोध का प्रोटोकॉल यहां दिया गया है:
POST https://slides.googleapis.com/v1/presentations/PRESENTATION_ID:batchUpdate
{ "requests": [ { "updateTextStyle": { "objectId": PAGE_ELEMENT_ID, "fields": "foregroundColor,bold,italic,fontFamily,fontSize,underline", "style": { "foregroundColor": { "opaqueColor": { "themeColor": "ACCENT5" } }, "bold": true, "italic": true, "underline": true, "fontFamily": "Corsiva", "fontSize": { "magnitude": 18, "unit": "PT" } }, "textRange": { "type": "ALL" } } } ] }
यहां बताया गया है कि इन अपडेट के बाद आकार टेक्स्ट कैसा दिखेगा:
Google Sheets से चार्ट इंपोर्ट करना
यहां दिए गए कोड सैंपल presentations.batchUpdate
में CreateSheetsChartRequest
तरीके का इस्तेमाल करके, शीट से चार्ट इंपोर्ट करने और उसे PAGE_ID की तय की गई स्लाइड पर रखने का तरीका बताया गया है.
इस अनुरोध के लिए, स्प्रेडशीट आईडी (SPREADSHEET_ID में बताया गया) और स्प्रेडशीट चार्ट आईडी (SPREADSHEET_CHART_ID में बताया गया है) की ज़रूरत होती है. Slides प्रज़ेंटेशन में मौजूद चार्ट आईडी PRESENTATION_CHART_ID ने तय किया है.
अनुरोध, Slides चार्ट के LinkingMode
को LINKED
पर भी सेट कर देता है, ताकि सोर्स स्प्रेडशीट पर चार्ट के अपडेट होने पर, एम्बेड किए गए चार्ट को अपडेट किया जा सके.
Sheets से चार्ट इंपोर्ट करने के लिए, अनुरोध का प्रोटोकॉल यहां दिया गया है:
POST https://slides.googleapis.com/v1/presentations/PRESENTATION_ID:batchUpdate
{ "requests": [ { "createSheetsChart": { "objectId": PRESENTATION_CHART_ID, "spreadsheetId": SPREADSHEET_ID, "chartId": SPREADSHEET_CHART_ID, "linkingMode": "LINKED", "elementProperties": { "pageObjectId": PAGE_ID, "size": { "width": { "magnitude": 4000000, "unit": "EMU" }, "height": { "magnitude": 4000000, "unit": "EMU" } }, "transform": { "scaleX": 1, "scaleY": 1, "translateX": 100000, "translateY": 100000, "unit": "EMU" } } } ] }
Sheets से चार्ट को रीफ़्रेश करना
यहां दिए गए presentations.batchUpdate
कोड सैंपल में, RefreshSheetsChartRequest
तरीके का इस्तेमाल करके, प्रज़ेंटेशन में लिंक किए गए चार्ट को रीफ़्रेश करने का तरीका बताया गया है. इसकी जगह, Sheets की सोर्स स्प्रेडशीट से चार्ट के नए वर्शन का इस्तेमाल किया जा सकता है. अनुरोध करने के लिए, Slides प्रज़ेंटेशन में चार्ट आईडी होना ज़रूरी है. इस बारे में PRESENTATION_CHART_ID में बताया गया है.
Sheets से चार्ट को रीफ़्रेश करने का अनुरोध प्रोटोकॉल यहां दिया गया है:
POST https://slides.googleapis.com/v1/presentations/PRESENTATION_ID:batchUpdate
{ "requests": [ { "refreshSheetsChart": { "objectId": PRESENTATION_CHART_ID } } ] }