Trabalhando com Imagens em Apresentações — Aspose.Slides FOSS for C++
Aspose.Slides FOSS for C++ permite incorporar imagens na coleção de imagens compartilhadas de uma apresentação e exibi‑las nos slides usando formas PictureFrame. As imagens também podem ser usadas como preenchimentos de fundo de forma via FillType::PICTURE.
Adicionando uma Imagem a partir de Arquivo
Carregue os bytes da imagem do disco e adicione-os à coleção de imagens da apresentação com pres.images().add_image(). Em seguida, coloque a imagem em um slide como um PictureFrame:
#include <Aspose/Slides/Foss/export/save_format.h>
#include <Aspose/Slides/Foss/image_collection.h>
#include <Aspose/Slides/Foss/picture_frame.h>
#include <Aspose/Slides/Foss/pp_image.h>
#include <Aspose/Slides/Foss/presentation.h>
#include <Aspose/Slides/Foss/shape_collection.h>
#include <Aspose/Slides/Foss/shape_type.h>
#include <Aspose/Slides/Foss/slide.h>
#include <Aspose/Slides/Foss/slide_collection.h>
#include <cstdint>
#include <fstream>
#include <iterator>
#include <vector>
using namespace Aspose::Slides::Foss;
int main() {
Presentation pres;
// Add the image to the shared collection
std::ifstream f("logo.png", std::ios::binary);
std::vector<std::uint8_t> data(
(std::istreambuf_iterator<char>(f)),
std::istreambuf_iterator<char>());
auto& img = pres.images().add_image(data);
// Place it on the slide as a PictureFrame
pres.slides()[0].shapes().add_picture_frame(
ShapeType::RECTANGLE, 50, 50, 300, 200, img);
pres.save("with-image.pptx", SaveFormat::PPTX);
return 0;
}Os quatro argumentos posicionais de add_picture_frame() são: x, y, width, height em pontos.
Adicionando uma Imagem a partir de um Vetor de Bytes
Se você já tem os bytes da imagem na memória (por exemplo, baixados de uma URL ou lidos de um banco de dados), passe‑os diretamente para add_image():
#include <Aspose/Slides/Foss/export/save_format.h>
#include <Aspose/Slides/Foss/image_collection.h>
#include <Aspose/Slides/Foss/pp_image.h>
#include <Aspose/Slides/Foss/presentation.h>
#include <Aspose/Slides/Foss/shape_collection.h>
#include <Aspose/Slides/Foss/shape_type.h>
#include <Aspose/Slides/Foss/slide.h>
#include <Aspose/Slides/Foss/slide_collection.h>
#include <cstdint>
#include <fstream>
#include <iterator>
#include <vector>
using namespace Aspose::Slides::Foss;
int main() {
// Simulate having bytes in memory
std::ifstream f("photo.jpg", std::ios::binary);
std::vector<std::uint8_t> image_bytes(
(std::istreambuf_iterator<char>(f)),
std::istreambuf_iterator<char>());
Presentation pres;
auto& img = pres.images().add_image(image_bytes);
pres.slides()[0].shapes().add_picture_frame(
ShapeType::RECTANGLE, 100, 80, 400, 250, img);
pres.save("from-bytes.pptx", SaveFormat::PPTX);
return 0;
}Posicionamento e Dimensionamento de um PictureFrame
O PictureFrame retornado por add_picture_frame() herda todas as propriedades de geometria Shape e pode ser reposicionado após a criação:
#include <Aspose/Slides/Foss/export/save_format.h>
#include <Aspose/Slides/Foss/image_collection.h>
#include <Aspose/Slides/Foss/picture_frame.h>
#include <Aspose/Slides/Foss/pp_image.h>
#include <Aspose/Slides/Foss/presentation.h>
#include <Aspose/Slides/Foss/shape_collection.h>
#include <Aspose/Slides/Foss/shape_type.h>
#include <Aspose/Slides/Foss/slide.h>
#include <Aspose/Slides/Foss/slide_collection.h>
#include <cstdint>
#include <fstream>
#include <iterator>
#include <vector>
using namespace Aspose::Slides::Foss;
int main() {
Presentation pres;
std::ifstream f("photo.jpg", std::ios::binary);
std::vector<std::uint8_t> data(
(std::istreambuf_iterator<char>(f)),
std::istreambuf_iterator<char>());
auto& img = pres.images().add_image(data);
auto& pf = pres.slides()[0].shapes().add_picture_frame(
ShapeType::RECTANGLE, 0, 0, 100, 100, img);
// Reposition and resize after creation
pf.set_x(50);
pf.set_y(100);
pf.set_width(350);
pf.set_height(250);
pres.save("positioned.pptx", SaveFormat::PPTX);
return 0;
}Usando uma Imagem como Preenchimento de Forma
Qualquer forma (não apenas PictureFrame) pode usar uma imagem como preenchimento de fundo. Defina fill_type para FillType::PICTURE e atribua a imagem ao formato de preenchimento de imagem:
#include <Aspose/Slides/Foss/auto_shape.h>
#include <Aspose/Slides/Foss/export/save_format.h>
#include <Aspose/Slides/Foss/fill_format.h>
#include <Aspose/Slides/Foss/fill_type.h>
#include <Aspose/Slides/Foss/image_collection.h>
#include <Aspose/Slides/Foss/picture_fill_mode.h>
#include <Aspose/Slides/Foss/pp_image.h>
#include <Aspose/Slides/Foss/presentation.h>
#include <Aspose/Slides/Foss/shape_collection.h>
#include <Aspose/Slides/Foss/shape_type.h>
#include <Aspose/Slides/Foss/slide.h>
#include <Aspose/Slides/Foss/slide_collection.h>
#include <cstdint>
#include <fstream>
#include <iterator>
#include <vector>
using namespace Aspose::Slides::Foss;
int main() {
Presentation pres;
std::ifstream f("background.png", std::ios::binary);
std::vector<std::uint8_t> data(
(std::istreambuf_iterator<char>(f)),
std::istreambuf_iterator<char>());
auto& img = pres.images().add_image(data);
auto& slide = pres.slides()[0];
auto& shape = slide.shapes().add_auto_shape(
ShapeType::ROUND_CORNER_RECTANGLE, 50, 50, 400, 250);
shape.fill_format().set_fill_type(FillType::PICTURE);
shape.fill_format().picture_fill_format().set_picture_fill_mode(PictureFillMode::STRETCH);
shape.fill_format().picture_fill_format().picture().set_image(&img);
pres.save("picture-fill.pptx", SaveFormat::PPTX);
return 0;
}PictureFillMode::STRETCH redimensiona a imagem para preencher toda a forma. Use TILE para padrões repetidos.