Darbas su vaizdais pristatymuose — Aspose.Slides FOSS for C++
Aspose.Slides FOSS for C++ lets you embed images in a presentation’s shared image collection and display them on slides using PictureFrame figūros. Vaizdus taip pat galima naudoti kaip figūros fono užpildus per FillType::PICTURE.
Vaizdo pridėjimas iš failo
Įkelkite vaizdo baitus iš disko ir pridėkite juos prie pristatymo vaizdų kolekcijos naudodami pres.images().add_image(). Tada įdėkite vaizdą į skaidrę kaip 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;
}Keturi poziciniai argumentai, skirti add_picture_frame() yra: x, y, width, height taškeliais.
Vaizdo pridėjimas iš baitų vektoriaus
Jei jau turite vaizdo baitus atmintyje (pvz., atsisiųstus iš URL arba perskaitytus iš duomenų bazės), perduokite juos tiesiogiai 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;
}PictureFrame pozicionavimas ir dydžio nustatymas
Šis PictureFrame grąžintas add_picture_frame() paveldi visus Shape geometrines savybes ir gali būti perkeliamas po sukūrimo:
#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;
}Vaizdo naudojimas kaip formos užpildas
Bet kuri figūra (ne tik PictureFrame) gali naudoti vaizdą kaip fono užpildą. Nustatykite fill_type į FillType::PICTURE ir priskirkite vaizdą paveikslėlio užpildymo formatui:
#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 ištempia vaizdą, kad užpildytų visą figūrą. Naudokite TILE kartojimui.