1

我有一个 Word 2016 插件,它使用 graphviz 创建图像并将相应的点代码存储在图像的 altdescription 中。我可以选择图像并将点代码加载回加载项中的编辑器。但这仅适用于我当前的 inlinePictures 实现。

        function getDataFromSelection() {


            Word.run(function (context) {

                var range = context.document.getSelection();
                var paragraphs = range.paragraphs;
                context.load(paragraphs);

                return context.sync().then(function () {

                    var pictures = paragraphs.items[0].inlinePictures;
                    context.load(pictures);

                    return context.sync().then(function () {
                        var picture = pictures.items[0];

                        editor.getSession().getDocument().setValue(picture.altTextDescription);
                    });
                });

            })
        }

如果所选图片在文档中自由浮动,如何获取?

插件的目标是使用点创建和编辑已经创建的图形。但是编辑部分是目前的问题。

4

1 回答 1

3

好问题。正如您正确推断出 inlinePictures 集合仅包括,请原谅冗余,inlinePicture 图像。浮动图像不包含在该集合中,我们将在 API 的未来迭代中添加。

我建议您使用一种解决方法来检查选择中是否有浮动图像。

您可以从选择中获取并分析OOXML,并找出选择中是否存在任何浮动图像。

此代码显示如何从选择中获取 OOXML:

   // Run a batch operation against the Word object model.
      Word.run(function (context) {

   // Queue a command to get the current selection and then 
   // create a proxy range object with the results.
      var range = context.document.getSelection();

   // Queue a commmand to get the OOXML of the current selection. 
      var ooxml = range.getOoxml();

   // Synchronize the document state by executing the queued-up commands, 
  // and return a promise to indicate task completion.
      return context.sync().then(function () {
      console.log('The OOXML read from the document was:  ' + ooxml.value);
      });  
}).catch(function (error) {
console.log('Error: ' + JSON.stringify(error));
if (error instanceof OfficeExtension.Error) {
    console.log('Debug info: ' + JSON.stringify(error.debugInfo));
    }
});

一旦你拥有了 OOXML,你实际上可以(使用字符串搜索或 XML 编辑器)获得其中的内容,如果寻找类似这个元素的东西,你就会知道那里有一个浮动图像。如您所见,您还可以获得替代文本和描述。如果需要,您可以使用该字符串替换您需要的 alt 文本属性,并可以写回 OOXML 以更新该浮动图像。这有点痛苦但可行,希望我们能尽快发布浮动图像集!感谢和快乐的编码!

   <w:drawing>
   <wp:anchor allowOverlap="1" layoutInCell="1" locked="0" behindDoc="0" relativeHeight="251659264" simplePos="1" distR="114300" distL="114300" distB="0" distT="0">
<wp:simplePos y="3710305" x="1729105"/>
<wp:positionH relativeFrom="margin">
  <wp:posOffset>1729105</wp:posOffset>
</wp:positionH>
<wp:positionV relativeFrom="margin">
  <wp:posOffset>3710305</wp:posOffset>
</wp:positionV>
<wp:extent cx="2847975" cy="2133600"/>
<wp:effectExtent r="9525" b="0" t="0" l="0"/>
<wp:wrapSquare wrapText="bothSides"/>
<wp:docPr title="alt text sample" name="Picture 1" descr="alt test description!!" id="1"/>
<wp:cNvGraphicFramePr>
  <a:graphicFrameLocks noChangeAspect="1" xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main"/>
</wp:cNvGraphicFramePr>
<a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
  <a:graphicData uri="http://schemas.openxmlformats.org/drawingml/2006/picture">
    <pic:pic xmlns:pic="http://schemas.openxmlformats.org/drawingml/2006/picture">
      <pic:nvPicPr>
        <pic:cNvPr name="stratus2.jpg" id="1"/>
        <pic:cNvPicPr/>
      </pic:nvPicPr>
      <pic:blipFill>
        <a:blip r:embed="rId4">
          <a:extLst>
            <a:ext uri="{28A0092B-C50C-407E-A947-70E740481C1C}">
              <a14:useLocalDpi val="0" xmlns:a14="http://schemas.microsoft.com/office/drawing/2010/main"/>
            </a:ext>
          </a:extLst>
        </a:blip>
        <a:stretch>
          <a:fillRect/>
       </a:stretch>
      </pic:blipFill>
      <pic:spPr>
        <a:xfrm>
          <a:off y="0" x="0"/>
          <a:ext cx="2847975" cy="2133600"/>
        </a:xfrm>
        <a:prstGeom prst="rect">
          <a:avLst/>
        </a:prstGeom>
      </pic:spPr>
    </pic:pic>
  </a:graphicData>
   </a:graphic>
   </wp:anchor>
  </w:drawing>
于 2016-02-18T21:55:21.423 回答