mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2024-12-23 04:16:50 +01:00
Implemented export and export as tools for the PaintProjectToolsPropertyInspector.
This commit is contained in:
parent
b2cbd6e759
commit
98ac4b9265
@ -25,12 +25,41 @@ SOFTWARE.
|
|||||||
#include "scene/gui/box_container.h"
|
#include "scene/gui/box_container.h"
|
||||||
#include "scene/gui/button.h"
|
#include "scene/gui/button.h"
|
||||||
#include "scene/gui/color_picker.h"
|
#include "scene/gui/color_picker.h"
|
||||||
|
#include "scene/gui/file_dialog.h"
|
||||||
#include "scene/gui/flow_container.h"
|
#include "scene/gui/flow_container.h"
|
||||||
#include "scene/gui/scroll_container.h"
|
#include "scene/gui/scroll_container.h"
|
||||||
|
|
||||||
|
#include "core/os/dir_access.h"
|
||||||
|
|
||||||
#include "../../nodes/paint_node.h"
|
#include "../../nodes/paint_node.h"
|
||||||
#include "../../nodes/paint_project.h"
|
#include "../../nodes/paint_project.h"
|
||||||
|
|
||||||
|
#ifdef TOOLS_ENABLED
|
||||||
|
#include "core/config/engine.h"
|
||||||
|
#include "editor/editor_node.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void PaintProjectToolsPropertyInspector::add_action_button(const String &callback, const String &hint, const String &icon, const String &theme_type) {
|
||||||
|
Button *button = memnew(Button);
|
||||||
|
|
||||||
|
Ref<Texture> icon_tex;
|
||||||
|
|
||||||
|
#ifdef TOOLS_ENABLED
|
||||||
|
if (EditorNode::get_singleton() && Engine::get_singleton()->is_editor_hint()) {
|
||||||
|
icon_tex = EditorNode::get_singleton()->get_gui_base()->get_theme_icon(icon, theme_type);
|
||||||
|
} else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
icon_tex = get_theme_icon(icon, theme_type);
|
||||||
|
}
|
||||||
|
|
||||||
|
button->set_icon(icon_tex);
|
||||||
|
button->set_tooltip(hint);
|
||||||
|
button->connect("pressed", this, callback);
|
||||||
|
|
||||||
|
_button_contianer->add_child(button);
|
||||||
|
}
|
||||||
|
|
||||||
void PaintProjectToolsPropertyInspector::_on_paint_node_selected(Node *p_paint_node) {
|
void PaintProjectToolsPropertyInspector::_on_paint_node_selected(Node *p_paint_node) {
|
||||||
PaintNode *paint_node = Object::cast_to<PaintNode>(p_paint_node);
|
PaintNode *paint_node = Object::cast_to<PaintNode>(p_paint_node);
|
||||||
|
|
||||||
@ -53,7 +82,6 @@ void PaintProjectToolsPropertyInspector::_on_paint_node_selected(Node *p_paint_n
|
|||||||
proj->connect("color_presets_changed", this, "_on_project_color_preset_changed");
|
proj->connect("color_presets_changed", this, "_on_project_color_preset_changed");
|
||||||
|
|
||||||
_current_paint_project = proj->get_instance_id();
|
_current_paint_project = proj->get_instance_id();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
PaintProjectToolsPropertyInspector::PaintProjectToolsPropertyInspector() {
|
PaintProjectToolsPropertyInspector::PaintProjectToolsPropertyInspector() {
|
||||||
@ -62,6 +90,19 @@ PaintProjectToolsPropertyInspector::PaintProjectToolsPropertyInspector() {
|
|||||||
_ignore_preset_changed_event = false;
|
_ignore_preset_changed_event = false;
|
||||||
_ignore_color_event = false;
|
_ignore_color_event = false;
|
||||||
|
|
||||||
|
Control *popups = memnew(Control);
|
||||||
|
add_child(popups);
|
||||||
|
popups->set_mouse_filter(MOUSE_FILTER_IGNORE);
|
||||||
|
|
||||||
|
_export_as_file_dialog = memnew(FileDialog);
|
||||||
|
popups->add_child(_export_as_file_dialog);
|
||||||
|
_export_as_file_dialog->set_access(FileDialog::ACCESS_FILESYSTEM);
|
||||||
|
_export_as_file_dialog->set_resizable(true);
|
||||||
|
_export_as_file_dialog->set_mode(FileDialog::MODE_SAVE_FILE);
|
||||||
|
_export_as_file_dialog->set_title("Export Image");
|
||||||
|
_export_as_file_dialog->add_filter("*.png");
|
||||||
|
_export_as_file_dialog->connect("file_selected", this, "_on_export_as_dialog_file_selected");
|
||||||
|
|
||||||
VBoxContainer *main_container = memnew(VBoxContainer);
|
VBoxContainer *main_container = memnew(VBoxContainer);
|
||||||
add_child(main_container);
|
add_child(main_container);
|
||||||
|
|
||||||
@ -70,22 +111,69 @@ PaintProjectToolsPropertyInspector::PaintProjectToolsPropertyInspector() {
|
|||||||
//_button_contianer->set_h_size_flags(SIZE_EXPAND_FILL);
|
//_button_contianer->set_h_size_flags(SIZE_EXPAND_FILL);
|
||||||
_button_contianer->set_v_size_flags(SIZE_EXPAND_FILL);
|
_button_contianer->set_v_size_flags(SIZE_EXPAND_FILL);
|
||||||
|
|
||||||
//Button *button = memnew(Button);
|
add_action_button("_on_export_pressed", "Export Image", "Save", "EditorIcons");
|
||||||
//button->set_tooltip("");
|
add_action_button("_on_export_as_pressed", "Export Image As", "Duplicate", "EditorIcons");
|
||||||
//button->connect("pressed", this, "");
|
|
||||||
//_button_contianer->add_child(button);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
PaintProjectToolsPropertyInspector::~PaintProjectToolsPropertyInspector() {
|
PaintProjectToolsPropertyInspector::~PaintProjectToolsPropertyInspector() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void PaintProjectToolsPropertyInspector::_notification(int p_what) {
|
void PaintProjectToolsPropertyInspector::_on_export_pressed() {
|
||||||
if (p_what == NOTIFICATION_THEME_CHANGED || p_what == NOTIFICATION_ENTER_TREE) {
|
PaintProject *paint_project = Object::cast_to<PaintProject>(ObjectDB::get_instance(_current_paint_project));
|
||||||
//_add_color_button->set_icon(get_theme_icon("Add", "EditorIcons"));
|
|
||||||
|
ERR_FAIL_COND(!paint_project);
|
||||||
|
|
||||||
|
String fn = paint_project->get_save_file_name();
|
||||||
|
|
||||||
|
if (!fn.empty()) {
|
||||||
|
_on_export_as_dialog_file_selected(fn);
|
||||||
|
} else {
|
||||||
|
_on_export_as_pressed();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void PaintProjectToolsPropertyInspector::_on_export_as_pressed() {
|
||||||
|
_export_as_file_dialog->popup_centered_ratio();
|
||||||
|
}
|
||||||
|
|
||||||
|
void PaintProjectToolsPropertyInspector::_on_export_as_dialog_file_selected(const String &f) {
|
||||||
|
PaintProject *paint_project = Object::cast_to<PaintProject>(ObjectDB::get_instance(_current_paint_project));
|
||||||
|
|
||||||
|
ERR_FAIL_COND(!paint_project);
|
||||||
|
|
||||||
|
if (f.empty()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Ref<Image> img = paint_project->render_image();
|
||||||
|
|
||||||
|
ERR_FAIL_COND(!img.is_valid());
|
||||||
|
|
||||||
|
Error err = img->save_png(f);
|
||||||
|
|
||||||
|
ERR_FAIL_COND_MSG(err != OK, "err != OK :" + itos(err));
|
||||||
|
|
||||||
|
String res_path = DirAccess::get_full_path("res://", DirAccess::ACCESS_FILESYSTEM);
|
||||||
|
String user_path = DirAccess::get_full_path("user://", DirAccess::ACCESS_FILESYSTEM);
|
||||||
|
|
||||||
|
if (f.begins_with(res_path)) {
|
||||||
|
paint_project->set_save_file_name(f.replace_first(res_path, "res:/"));
|
||||||
|
} else if (f.begins_with(user_path)) {
|
||||||
|
paint_project->set_save_file_name(f.replace_first(res_path, "user:/"));
|
||||||
|
} else {
|
||||||
|
paint_project->set_save_file_name(f);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//void PaintProjectToolsPropertyInspector::_notification(int p_what) {
|
||||||
|
//if (p_what == NOTIFICATION_THEME_CHANGED || p_what == NOTIFICATION_ENTER_TREE) {
|
||||||
|
//_add_color_button->set_icon(get_theme_icon("Add", "EditorIcons"));
|
||||||
|
//}
|
||||||
|
//}
|
||||||
|
|
||||||
void PaintProjectToolsPropertyInspector::_bind_methods() {
|
void PaintProjectToolsPropertyInspector::_bind_methods() {
|
||||||
//ClassDB::bind_method(D_METHOD("_on_grid_color_button_changed"), &PaintProjectToolsPropertyInspector::_on_grid_color_button_changed);
|
ClassDB::bind_method(D_METHOD("add_action_button", "callback", "hint", "icon", "theme_type"), &PaintProjectToolsPropertyInspector::add_action_button);
|
||||||
|
|
||||||
|
ClassDB::bind_method(D_METHOD("_on_export_pressed"), &PaintProjectToolsPropertyInspector::_on_export_pressed);
|
||||||
|
ClassDB::bind_method(D_METHOD("_on_export_as_pressed"), &PaintProjectToolsPropertyInspector::_on_export_as_pressed);
|
||||||
|
ClassDB::bind_method(D_METHOD("_on_export_as_dialog_file_selected"), &PaintProjectToolsPropertyInspector::_on_export_as_dialog_file_selected);
|
||||||
}
|
}
|
||||||
|
@ -33,11 +33,13 @@ class PaintProject;
|
|||||||
class HFlowContainer;
|
class HFlowContainer;
|
||||||
class ColorSelectorButton;
|
class ColorSelectorButton;
|
||||||
class Button;
|
class Button;
|
||||||
|
class FileDialog;
|
||||||
|
|
||||||
class PaintProjectToolsPropertyInspector : public PaintCustomPropertyInspector {
|
class PaintProjectToolsPropertyInspector : public PaintCustomPropertyInspector {
|
||||||
GDCLASS(PaintProjectToolsPropertyInspector, PaintCustomPropertyInspector);
|
GDCLASS(PaintProjectToolsPropertyInspector, PaintCustomPropertyInspector);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
void add_action_button(const String &callback, const String &hint, const String &icon, const String &theme_type);
|
||||||
|
|
||||||
void _on_paint_node_selected(Node *paint_node);
|
void _on_paint_node_selected(Node *paint_node);
|
||||||
|
|
||||||
@ -45,11 +47,16 @@ public:
|
|||||||
~PaintProjectToolsPropertyInspector();
|
~PaintProjectToolsPropertyInspector();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
void _on_export_pressed();
|
||||||
|
void _on_export_as_pressed();
|
||||||
|
void _on_export_as_dialog_file_selected(const String &f);
|
||||||
|
|
||||||
void _notification(int p_what);
|
//void _notification(int p_what);
|
||||||
|
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
|
FileDialog *_export_as_file_dialog;
|
||||||
|
|
||||||
HFlowContainer *_button_contianer;
|
HFlowContainer *_button_contianer;
|
||||||
|
|
||||||
ObjectID _current_paint_node;
|
ObjectID _current_paint_node;
|
||||||
|
Loading…
Reference in New Issue
Block a user