图像
演示文稿中幻灯片的图像
图像使演示文稿更具吸引力和趣味性。在 Microsoft PowerPoint 中,您可以从文件、互联网或其他位置向幻灯片插入图片。同样,Aspose.Slides 也允许您通过多种方式向演示文稿的幻灯片添加图像。
Info
如果您想将图像作为帧对象添加——尤其是计划使用标准格式选项来更改其大小、添加效果等——请参阅 Picture Frame。Note
您可以操作涉及图像和 PowerPoint 演示文稿的输入/输出,以将图像从一种格式转换为另一种格式。请参阅以下页面:将 image to JPG 转换;将 JPG to image 转换;将 JPG to PNG 转换, 将 PNG to JPG 转换;将 PNG to SVG 转换, 将 SVG to PNG 转换。Aspose.Slides 支持在这些常用格式中对图像进行操作:JPEG、PNG、GIF 等。
向幻灯片添加本地存储的图像
您可以将计算机上的一张或多张图像添加到演示文稿的幻灯片中。下面的 JavaScript 示例代码展示了如何向幻灯片添加图像:
var pres = new aspose.slides.Presentation();
try {
var slide = pres.getSlides().get_Item(0);
var picture;
var image = aspose.slides.Images.fromFile("image.png");
try {
picture = pres.getImages().addImage(image);
} finally {
if (image != null) {
image.dispose();
}
}
slide.getShapes().addPictureFrame(aspose.slides.ShapeType.Rectangle, 10, 10, 100, 100, picture);
pres.save("pres.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
从流向幻灯片添加图像
如果要添加到幻灯片的图像在本地不可用,您可以直接从网络添加该图像。
下面的示例代码展示了如何在 JavaScript 中将网络图像添加到幻灯片:
var pres = new aspose.slides.Presentation();
try {
// 访问第一张幻灯片
var sld = pres.getSlides().get_Item(0);
// 加载 Excel 文件到流
var readStream = fs.readFileSync("book1.xlsx");
var byteArray = Array.from(readStream);
// 创建用于嵌入的数据对象
var dataInfo = new aspose.slides.OleEmbeddedDataInfo(java.newArray("byte", byteArray), "xlsx");
// 添加 Ole 对象框架形状
var oleObjectFrame = sld.getShapes().addOleObjectFrame(0, 0, pres.getSlideSize().getSize().getWidth(), pres.getSlideSize().getSize().getHeight(), dataInfo);
// 将 PPTX 文件写入磁盘
pres.save("OleEmbed_out.pptx", aspose.slides.SaveFormat.Pptx);
} catch (e) {console.log(e);
} finally {
if (pres != null) {
pres.dispose();
}
}
向幻灯片母版添加图像
幻灯片母版是存储并控制其下所有幻灯片信息(主题、布局等)的顶层幻灯片。因此,当您向幻灯片母版添加图像时,该图像会出现在该母版下的每一张幻灯片上。
下面的 JavaScript 示例代码展示了如何向幻灯片母版添加图像:
var pres = new aspose.slides.Presentation();
try {
var slide = pres.getSlides().get_Item(0);
var masterSlide = slide.getLayoutSlide().getMasterSlide();
var picture;
var image = aspose.slides.Images.fromFile("image.png");
try {
picture = pres.getImages().addImage(image);
} finally {
if (image != null) {
image.dispose();
}
}
masterSlide.getShapes().addPictureFrame(aspose.slides.ShapeType.Rectangle, 10, 10, 100, 100, picture);
pres.save("pres.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (pres != null) {
pres.dispose();
}
}
将图像设为幻灯片背景
您可能决定将图片用作特定幻灯片或多张幻灯片的背景。在这种情况下,请参阅 Setting Images as Backgrounds for Slides。
向演示文稿添加 SVG
您可以使用属于 ShapeCollection 类的 addPictureFrame 方法将任何图像添加或插入到演示文稿中。
要基于 SVG 图像创建图像对象,可按以下方式操作:
- 创建 SvgImage 对象以将其插入 ImageShapeCollection
- 从 ISvgImage 创建 PPImage 对象
- 使用 PPImage 类创建 PictureFrame 对象
下面的示例代码展示了如何实现上述步骤以将 SVG 图像添加到演示文稿中:
// 实例化表示 PPTX 文件的 Presentation 类
var pres = new aspose.slides.Presentation();
try {
var svgContent = java.newInstanceSync("java.lang.String", java.newInstanceSync("java.io.FileInputStream", java.newInstanceSync("java.io.File", "image.svg")));
var svgImage = new aspose.slides.SvgImage(svgContent);
var ppImage = pres.getImages().addImage(svgImage);
pres.getSlides().get_Item(0).getShapes().addPictureFrame(aspose.slides.ShapeType.Rectangle, 0, 0, ppImage.getWidth(), ppImage.getHeight(), ppImage);
pres.save("output.pptx", aspose.slides.SaveFormat.Pptx);
} catch (e) {console.log(e);
} finally {
if (pres != null) {
pres.dispose();
}
}
将 SVG 转换为形状集合
Aspose.Slides 将 SVG 转换为形状集合的功能与 PowerPoint 用于处理 SVG 图像的功能类似:

该功能由 ShapeCollection 类的一个重载的 addGroupShape 方法提供,首个参数为 SvgImage 对象。
下面的示例代码展示了如何使用上述方法将 SVG 文件转换为形状集合:
// 创建新的演示文稿
var presentation = new aspose.slides.Presentation();
try {
// 读取 SVG 文件内容
var svgContent = java.newInstanceSync("java.io.FileInputStream", java.newInstanceSync("java.io.File", "image.svg"));
// 创建 SvgImage 对象
var svgImage = new aspose.slides.SvgImage(svgContent);
// 获取幻灯片尺寸
var slideSize = presentation.getSlideSize().getSize();
// 将 SVG 图像转换为形状组,并按幻灯片尺寸进行缩放
presentation.getSlides().get_Item(0).getShapes().addGroupShape(svgImage, 0.0, 0.0, slideSize.getWidth(), slideSize.getHeight());
// 以 PPTX 格式保存演示文稿
presentation.save("output.pptx", aspose.slides.SaveFormat.Pptx);
} catch (e) {console.log(e);
} finally {
if (presentation != null) {
presentation.dispose();
}
}
在幻灯片中将图像添加为 EMF
Aspose.Slides for Node.js via Java 允许您从 Excel 工作表生成 EMF 图像,并使用 Aspose.Cells 将这些图像以 EMF 形式添加到幻灯片中。
下面的示例代码展示了如何完成上述任务:
var book = java.newInstanceSync("aspose.cells.Workbook", "chart.xlsx");
var sheet = book.getWorksheets().get(0);
var options = java.newInstanceSync("aspose.cells.ImageOrPrintOptions");
options.setHorizontalResolution(200);
options.setVerticalResolution(200);
options.setImageType(java.getStaticFieldValue("ImageType", "EMF"));
// Save the workbook to stream
var sr = java.newInstanceSync("SheetRender", sheet, options);
var pres = new aspose.slides.Presentation();
try {
pres.getSlides().removeAt(0);
var EmfSheetName = "";
for (var j = 0; j < sr.getPageCount(); j++) {
EmfSheetName = ((("test" + sheet.getName()) + " Page") + (j + 1)) + ".out.emf";
sr.toImage(j, EmfSheetName);
var picture;
var image = aspose.slides.Images.fromFile(EmfSheetName);
try {
picture = pres.getImages().addImage(image);
} finally {
if (image != null) {
image.dispose();
}
}
var slide = pres.getSlides().addEmptySlide(pres.getLayoutSlides().getByType(aspose.slides.SlideLayoutType.Blank));
var m = slide.getShapes().addPictureFrame(aspose.slides.ShapeType.Rectangle, 0, 0, pres.getSlideSize().getSize().getWidth(), pres.getSlideSize().getSize().getHeight(), picture);
}
pres.save("output.pptx", aspose.slides.SaveFormat.Pptx);
} catch (e) {console.log(e);
} finally {
if (pres != null) {
pres.dispose();
}
}
替换图像集合中的图像
Aspose.Slides 让您能够替换演示文稿图像集合(包括幻灯片形状使用的图像)中的图像。本节展示了更新集合中图像的几种方法。API 提供了直接使用原始字节数据、IImage 实例或集合中已存在的另一图像来替换图像的简便方法。
请按以下步骤操作:
- 使用 Presentation 类加载包含图像的演示文稿文件。
- 将新图像从文件加载到字节数组中。
- 使用字节数组将目标图像替换为新图像。
- 在第二种方法中,将图像加载到 IImage 对象并使用该对象替换目标图像。
- 在第三种方法中,将目标图像替换为演示文稿图像集合中已存在的图像。
- 将修改后的演示文稿写入为 PPTX 文件。
// 实例化表示演示文稿文件的 Presentation 类。
const presentation = new aspose.slides.Presentation("sample.pptx");
try {
// 第一种方法。
const imageData = java.newArray("byte", Array.from(fs.readFileSync("image0.jpeg")));
let oldImage = presentation.getImages().get_Item(0);
oldImage.replaceImage(imageData);
// 第二种方法。
const newImage = aspose.slides.Images.fromFile("image1.png");
oldImage = presentation.getImages().get_Item(1);
oldImage.replaceImage(newImage);
newImage.dispose();
// 第三种方法。
oldImage = presentation.getImages().get_Item(2);
oldImage.replaceImage(presentation.getImages().get_Item(3));
// 将演示文稿保存到文件。
presentation.save("output.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
presentation.dispose();
}
Info
使用 Aspose 免费的 Text to GIF 转换器,您可以轻松为文本添加动画、从文本创建 GIF 等。FAQ
插入后原始图像分辨率是否保持不变?
是的。源像素会被保留,但最终外观取决于幻灯片上 picture 的缩放方式以及保存时是否应用了压缩。
一次性在数十张幻灯片上替换同一徽标的最佳方法是什么?
将徽标放在母版幻灯片或布局上,并在演示文稿的图像集合中替换它——更改会传播到所有使用该资源的元素。
插入的 SVG 能否转换为可编辑的形状?
可以。您可以将 SVG 转换为一组形状,之后单独的部分即可使用标准形状属性进行编辑。
如何一次性为多张幻灯片设置图片作为背景?
在母版幻灯片或相关布局上 Assign the image as the background,使用该母版/布局的所有幻灯片都会继承该背景。
如何防止因大量图片导致演示文稿体积“膨胀”?
复用单一图像资源而非重复,选择合适的分辨率,保存时进行压缩,并在适当情况下将重复图形放在母版上。