Google幻灯片API,将图像定位在幻灯片上

时间:2017-12-05 19:47:56

标签: google-api-client google-slides-api

我正在使用Google幻灯片API将图片插入Google幻灯片,我的代码是

    $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'
          )
        )
      )
    ));

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

Slide Created by Google Slides API

我希望图像显示在中心并从顶部减少填充。有什么帮助吗?

2 个答案:

答案 0 :(得分:3)

Google幻灯片API可能会将您的转换请求结果更改为您未提出的问题:

  

创建页面元素时,可以指定提供特定视觉效果的大小和变换。但是,API可能会将您提供的值替换为产生相同视觉外观的其他值。通常,如果您使用API​​编写大小,则无法保证返回相同的大小。

来源:https://developers.google.com/slides/how-tos/transform#the_slides_api_might_refactor_your_values

将图片插入Google幻灯片中心的相对安全的方式是通过ReplaceAllShapesWithImageRequest插入。

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

enter image description here

然后用图片替换形状(以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",
        "replaceMethod": "CENTER_INSIDE",
        "pageObjectIds": [presentation.getSlides()[0].getObjectId()],
        "containsText": {
          "text": "{{CENTERED_SHAPE}}",
          "matchCase": false
        }
     }
   }];

   Slides.Presentations.batchUpdate({'requests': requests}, presentation.getId());
}

幻灯片中心的结果图像:

enter image description here

答案 1 :(得分:0)

幻灯片图像定位的工作原理是根据给定的大小创建矩形,在该矩形中拟合实际图像的方面,然后应用变换。因此,如果您提供的尺寸与图像的宽高比不匹配,您通常会获得额外的填充。

确保您提供的尺寸与图像尺寸相匹配,然后使用pageSize和图像尺寸进行数学计算,以确定要使用的translateX / translateY的正确值。