Route layer menu clear through app core
This commit is contained in:
@@ -140,6 +140,33 @@ bool apply_brush_preset_plan(App& app, const std::shared_ptr<Brush>& brush)
|
||||
return status.ok();
|
||||
}
|
||||
|
||||
class LegacyDocumentCanvasClearServices final : public pp::app::DocumentCanvasClearServices {
|
||||
public:
|
||||
explicit LegacyDocumentCanvasClearServices(App& app) noexcept
|
||||
: app_(app)
|
||||
{
|
||||
}
|
||||
|
||||
void clear_current_canvas(float r, float g, float b, float a) override
|
||||
{
|
||||
if (!app_.canvas || !app_.canvas->m_canvas)
|
||||
return;
|
||||
|
||||
app_.canvas->m_canvas->clear({ r, g, b, a });
|
||||
}
|
||||
|
||||
private:
|
||||
App& app_;
|
||||
};
|
||||
|
||||
void execute_document_canvas_clear_plan(App& app, const pp::app::DocumentCanvasClearPlan& plan)
|
||||
{
|
||||
LegacyDocumentCanvasClearServices services(app);
|
||||
const auto status = pp::app::execute_document_canvas_clear_plan(plan, services);
|
||||
if (!status.ok())
|
||||
LOG("Canvas clear failed: %s", status.message);
|
||||
}
|
||||
|
||||
bool apply_document_export_menu_plan(App& app, pp::app::DocumentExportMenuKind kind)
|
||||
{
|
||||
class LegacyDocumentExportMenuServices final : public pp::app::DocumentExportMenuServices {
|
||||
@@ -391,29 +418,7 @@ public:
|
||||
|
||||
void clear_canvas(const pp::app::DocumentCanvasClearPlan& plan) override
|
||||
{
|
||||
class LegacyDocumentCanvasClearServices final : public pp::app::DocumentCanvasClearServices {
|
||||
public:
|
||||
explicit LegacyDocumentCanvasClearServices(App& app) noexcept
|
||||
: app_(app)
|
||||
{
|
||||
}
|
||||
|
||||
void clear_current_canvas(float r, float g, float b, float a) override
|
||||
{
|
||||
if (!app_.canvas || !app_.canvas->m_canvas)
|
||||
return;
|
||||
|
||||
app_.canvas->m_canvas->clear({ r, g, b, a });
|
||||
}
|
||||
|
||||
private:
|
||||
App& app_;
|
||||
};
|
||||
|
||||
LegacyDocumentCanvasClearServices services(app_);
|
||||
const auto status = pp::app::execute_document_canvas_clear_plan(plan, services);
|
||||
if (!status.ok())
|
||||
LOG("Canvas clear failed: %s", status.message);
|
||||
execute_document_canvas_clear_plan(app_, plan);
|
||||
}
|
||||
|
||||
void show_message_box() override
|
||||
@@ -581,8 +586,16 @@ public:
|
||||
|
||||
void clear_current_layer() override
|
||||
{
|
||||
if (app_.canvas && app_.canvas->m_canvas)
|
||||
app_.canvas->m_canvas->clear();
|
||||
const auto plan = pp::app::plan_document_canvas_clear(
|
||||
app_.canvas && app_.canvas->m_canvas,
|
||||
1.0F,
|
||||
1.0F,
|
||||
1.0F,
|
||||
0.0F);
|
||||
if (!plan)
|
||||
return;
|
||||
|
||||
execute_document_canvas_clear_plan(app_, plan.value());
|
||||
}
|
||||
|
||||
void show_rename_dialog() override
|
||||
|
||||
Reference in New Issue
Block a user