Add image import service boundary
This commit is contained in:
@@ -143,17 +143,44 @@ public:
|
||||
if (!import_plan)
|
||||
return;
|
||||
|
||||
if (import_plan.value().imports_equirectangular)
|
||||
{
|
||||
Canvas::I->import_equirectangular(path);
|
||||
}
|
||||
else
|
||||
{
|
||||
auto m = static_cast<CanvasModeTransform*>(app_ptr->canvas->m_canvas->modes[(int)kCanvasMode::Import][0]);
|
||||
m->m_action = CanvasModeTransform::ActionType::Import;
|
||||
m->m_source_image = std::move(img);
|
||||
Canvas::set_mode(kCanvasMode::Import);
|
||||
}
|
||||
class LegacyDocumentImageImportServices final : public pp::app::DocumentImageImportServices {
|
||||
public:
|
||||
LegacyDocumentImageImportServices(App& app, Image& image) noexcept
|
||||
: app_(app)
|
||||
, image_(image)
|
||||
{
|
||||
}
|
||||
|
||||
void import_equirectangular(std::string_view import_path) override
|
||||
{
|
||||
if (Canvas::I)
|
||||
Canvas::I->import_equirectangular(std::string(import_path));
|
||||
}
|
||||
|
||||
void enter_transform_import(std::string_view) override
|
||||
{
|
||||
if (!app_.canvas || !app_.canvas->m_canvas)
|
||||
return;
|
||||
|
||||
auto* mode = static_cast<CanvasModeTransform*>(
|
||||
app_.canvas->m_canvas->modes[(int)kCanvasMode::Import][0]);
|
||||
mode->m_action = CanvasModeTransform::ActionType::Import;
|
||||
mode->m_source_image = std::move(image_);
|
||||
Canvas::set_mode(kCanvasMode::Import);
|
||||
}
|
||||
|
||||
private:
|
||||
App& app_;
|
||||
Image& image_;
|
||||
};
|
||||
|
||||
LegacyDocumentImageImportServices services(*app_ptr, img);
|
||||
const auto status = pp::app::execute_document_image_import_plan(
|
||||
import_plan.value(),
|
||||
path,
|
||||
services);
|
||||
if (!status.ok())
|
||||
LOG("Image import failed: %s", status.message);
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user