Erweiterter Google Präsentationen-Dienst

Mit dem erweiterten Google Präsentationen-Dienst können Sie über folgenden Befehl auf die Slides API zugreifen: Apps Script. Mit diesem Dienst können Skripts Inhalte in Google Präsentationen lesen und bearbeiten.

Referenz

Detaillierte Informationen zu diesem Dienst finden Sie in der Referenzdokumentation für die Slides API. Wie alle erweiterten Dienste in Apps Script verwendet der erweiterte Dienst für Google Präsentationen die dieselben Objekte, Methoden und Parameter wie die öffentliche API. Weitere Informationen finden Sie unter Wie Methodensignaturen bestimmt werden.

Informationen zum Melden von Problemen und zum Support erhalten Sie in der Leitfaden für Google Präsentationen

Beispielcode

Im Beispielcode unten wird Version 1 der API verwendet.

Neue Präsentation erstellen

Das folgende Beispiel zeigt, wie Sie mithilfe der Erweiterter Google Präsentationen-Dienst. Er entspricht dem Parameter Präsentationen erstellen Rezeptbeispiel.

Erweitert/Folien.gs
/**
 * Create a new presentation.
 * @return {string} presentation Id.
 * @see https://developers.google.com/slides/api/reference/rest/v1/presentations/create
 */
function createPresentation() {
  try {
    const presentation =
      Slides.Presentations.create({'title': 'MyNewPresentation'});
    console.log('Created presentation with ID: ' + presentation.presentationId);
    return presentation.presentationId;
  } catch (e) {
    // TODO (developer) - Handle exception
    console.log('Failed with error %s', e.message);
  }
}

Neue Folie erstellen

Das folgende Beispiel zeigt, wie Sie eine neue Folie in einer Präsentation erstellen. an einem bestimmten Index und mit einem vordefinierten Layout. Er entspricht dem Parameter Neue Folie erstellen Rezeptbeispiel.

Erweitert/Folien.gs
/**
 * Create a new slide.
 * @param {string} presentationId The presentation to add the slide to.
 * @return {Object} slide
 * @see https://developers.google.com/slides/api/reference/rest/v1/presentations/batchUpdate
 */
function createSlide(presentationId) {
  // You can specify the ID to use for the slide, as long as it's unique.
  const pageId = Utilities.getUuid();

  const requests = [{
    'createSlide': {
      'objectId': pageId,
      'insertionIndex': 1,
      'slideLayoutReference': {
        'predefinedLayout': 'TITLE_AND_TWO_COLUMNS'
      }
    }
  }];
  try {
    const slide =
      Slides.Presentations.batchUpdate({'requests': requests}, presentationId);
    console.log('Created Slide with ID: ' + slide.replies[0].createSlide.objectId);
    return slide;
  } catch (e) {
    // TODO (developer) - Handle Exception
    console.log('Failed with error %s', e.message);
  }
}

Objekt-IDs für Seitenelement aufrufen

Das folgende Beispiel zeigt, wie die Objekt-IDs für jede Seite abgerufen werden mithilfe einer Feldmaske auf einer bestimmten Folie. Er entspricht dem Parameter Element-Objekt-IDs von einer Seite lesen Rezeptbeispiel.

Erweitert/Folien.gs
/**
 * Read page element IDs.
 * @param {string} presentationId The presentation to read from.
 * @param {string} pageId The page to read from.
 * @return {Object} response
 * @see https://developers.google.com/slides/api/reference/rest/v1/presentations.pages/get
 */
function readPageElementIds(presentationId, pageId) {
  // You can use a field mask to limit the data the API retrieves
  // in a get request, or what fields are updated in an batchUpdate.
  try {
    const response = Slides.Presentations.Pages.get(
        presentationId, pageId, {'fields': 'pageElements.objectId'});
    console.log(response);
    return response;
  } catch (e) {
    // TODO (developer) - Handle Exception
    console.log('Failed with error %s', e.message);
  }
}

Neues Textfeld hinzufügen

Das folgende Beispiel zeigt, wie Sie einer Folie ein neues Textfeld Text hinzufügen. Er entspricht dem Parameter Ein Textfeld auf einer Folie einfügen Rezeptbeispiel.

Erweitert/Folien.gs
/**
 * Add a new text box with text to a page.
 * @param {string} presentationId The presentation ID.
 * @param {string} pageId The page ID.
 * @return {Object} response
 * @see https://developers.google.com/slides/api/reference/rest/v1/presentations/batchUpdate
 */
function addTextBox(presentationId, pageId) {
  // You can specify the ID to use for elements you create,
  // as long as the ID is unique.
  const pageElementId = Utilities.getUuid();

  const requests = [{
    'createShape': {
      'objectId': pageElementId,
      'shapeType': 'TEXT_BOX',
      'elementProperties': {
        'pageObjectId': pageId,
        'size': {
          'width': {
            'magnitude': 150,
            'unit': 'PT'
          },
          'height': {
            'magnitude': 50,
            'unit': 'PT'
          }
        },
        'transform': {
          'scaleX': 1,
          'scaleY': 1,
          'translateX': 200,
          'translateY': 100,
          'unit': 'PT'
        }
      }
    }
  }, {
    'insertText': {
      'objectId': pageElementId,
      'text': 'My Added Text Box',
      'insertionIndex': 0
    }
  }];
  try {
    const response =
      Slides.Presentations.batchUpdate({'requests': requests}, presentationId);
    console.log('Created Textbox with ID: ' +
      response.replies[0].createShape.objectId);
    return response;
  } catch (e) {
    // TODO (developer) - Handle Exception
    console.log('Failed with error %s', e.message);
  }
}

Text in einer Form formatieren

Das folgende Beispiel zeigt, wie Sie den Text einer Form formatieren, Farbe, Schriftart und Unterstreichung des Textes. Er entspricht dem Parameter Text in einer Form oder einem Textfeld formatieren Rezeptbeispiel.

Erweitert/Folien.gs
/**
 * Format the text in a shape.
 * @param {string} presentationId The presentation ID.
 * @param {string} shapeId The shape ID.
 * @return {Object} replies
 * @see https://developers.google.com/slides/api/reference/rest/v1/presentations/batchUpdate
 */
function formatShapeText(presentationId, shapeId) {
  const requests = [{
    'updateTextStyle': {
      'objectId': shapeId,
      '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'
      }
    }
  }];
  try {
    const response =
      Slides.Presentations.batchUpdate({'requests': requests}, presentationId);
    return response.replies;
  } catch (e) {
    // TODO (developer) - Handle Exception
    console.log('Failed with error %s', e.message);
  }
}

Best Practices

Batch-Updates

Wenn Sie den erweiterten Google Präsentationen-Dienst verwenden, werden mehrere Anfragen in einem Array kombiniert. anstatt batchUpdate in einer Schleife aufzurufen.

Nicht zulässig: Rufen Sie batchUpdate in einer Schleife auf.

var titles = ["slide 1", "slide 2"];
for (var i = 0; i < titles.length; i++) {
  Slides.Presentations.batchUpdate(preso, {
    requests: [{
      createSlide: ...
    }]
  });
}

Richtig: Rufen Sie batchUpdate mit einem Array von Aktualisierungen.

var requests = [];
var titles = ["slide 1", "slide 2"];
for (var i = 0; i < titles.length; i++) {
  requests.push({ createSlide: ... });
}

Slides.Presentations.batchUpdate(preso, {
  requests: requests
});