Google Slides API,幻灯片上图像的定位

问题描述 投票:0回答:2

我正在使用 Google Slides API 将图像插入到 Google Slide,我的代码是

    $emu4M = array('magnitude' => 5500000, 'unit' => 'EMU');
    $requests = array();
    $requests[] = new Google_Service_Slides_Request(array(
      'createImage' => array (
        'objectId' => '303030',
        'url' => $imageUrl,
        'elementProperties' => array(
          'pageObjectId' => $pageId,
          'size' => array(
            'height' => $emu4M,
            'width' => $emu4M
          ),
          'transform' => array(
            'scaleX' => 1,
            'scaleY' => 1,
            'translateX' => 5000,
            'translateY' => 5000,
            'unit' => 'EMU'
          )
        )
      )
    ));

工作正常,但插入的图像是这样的

我希望图像出现在中心并减少顶部的填充。有什么帮助吗?

google-api-client google-slides-api
2个回答
3
投票

Google Slides API 可能会将您的转换请求结果更改为您未要求的结果:

创建页面元素时,您可以指定提供特定视觉结果的尺寸和变换。但是,API 可能会将您提供的值替换为产生相同视觉外观的其他值。一般来说,如果您使用 API 写入尺寸,则不能保证返回相同的尺寸。

来源:https://developers.google.com/slides/api/guides/transform#the_might_refactor_your_values


将图像插入 Google Slide 中心的相对安全的方法是通过

ReplaceAllShapesWithImageRequest
插入。

首先您需要创建占位符形状并将其放置在幻灯片的中心:

然后用您的图像替换形状(Google Apps 脚本语言的示例):

function insertImageCentered()
{
  var presentation = SlidesApp.getActivePresentation();
  
  var requests = [{
    "replaceAllShapesWithImage": {
      "imageUrl": "https://docs.google.com/drawings/d/e/2PACX-1vR5mi6ujksb_2WtTFmk39IPYBIBlJ6WkzM1nsys9cT4Wquik627DDIRXzoYTgHPKX3fcvJzG9inDmJt/pub?w=960&h=720",
        "imageReplaceMethod": "CENTER_INSIDE",
        "pageObjectIds": [presentation.getSlides()[0].getObjectId()],
        "containsText": {
          "text": "{{CENTERED_SHAPE}}",
          "matchCase": false
        }
     }
   }];
  
   Slides.Presentations.batchUpdate({'requests': requests}, presentation.getId());
}

幻灯片中心的结果图像:


1
投票

幻灯片图像定位的工作原理是根据给定的大小创建一个矩形,使实际图像的纵横比适合该矩形,然后应用变换。因此,如果您提供的尺寸与图像的长宽比不匹配,您通常会得到额外的填充。

确保您提供的尺寸与图像的尺寸相匹配,然后对 pageSize 和图像尺寸进行一些数学运算,找出要使用的正确的 translateX/translateY 值。

© www.soinside.com 2019 - 2024. All rights reserved.