Implemented the paint editor plugin. Also reimplemented PaintWindow's ui.

This commit is contained in:
Relintai 2022-04-16 19:08:19 +02:00
parent 79aa630959
commit e540e4e414
11 changed files with 405 additions and 1426 deletions

View File

@ -6,8 +6,6 @@ module_env = env.Clone()
module_env.add_source_files(env.modules_sources,"register_types.cpp") module_env.add_source_files(env.modules_sources,"register_types.cpp")
module_env.add_source_files(env.modules_sources,"paint_utilities.cpp")
module_env.add_source_files(env.modules_sources,"actions/paint_action.cpp") module_env.add_source_files(env.modules_sources,"actions/paint_action.cpp")
module_env.add_source_files(env.modules_sources,"actions/brighten_action.cpp") module_env.add_source_files(env.modules_sources,"actions/brighten_action.cpp")
module_env.add_source_files(env.modules_sources,"actions/brush_action.cpp") module_env.add_source_files(env.modules_sources,"actions/brush_action.cpp")
@ -38,7 +36,6 @@ module_env.add_source_files(env.modules_sources,"paint_layer_button.cpp")
module_env.add_source_files(env.modules_sources,"paint_navbar.cpp") module_env.add_source_files(env.modules_sources,"paint_navbar.cpp")
module_env.add_source_files(env.modules_sources,"paint_selection_box.cpp") module_env.add_source_files(env.modules_sources,"paint_selection_box.cpp")
module_env.add_source_files(env.modules_sources,"paint_settings.cpp") module_env.add_source_files(env.modules_sources,"paint_settings.cpp")
module_env.add_source_files(env.modules_sources,"paint_text_info.cpp")
module_env.add_source_files(env.modules_sources,"paint_utilities.cpp") module_env.add_source_files(env.modules_sources,"paint_utilities.cpp")
module_env.add_source_files(env.modules_sources,"paint_visual_grid.cpp") module_env.add_source_files(env.modules_sources,"paint_visual_grid.cpp")

View File

@ -32,6 +32,11 @@ void PaintColorGrid::change_color_to(const Color &color) {
} }
void PaintColorGrid::add_color_prefab(const Color &color) { void PaintColorGrid::add_color_prefab(const Color &color) {
Button *button = memnew(Button); Button *button = memnew(Button);
button->set_custom_minimum_size(Size2(25, 25));
button->set_h_size_flags(SIZE_EXPAND_FILL);
button->set_v_size_flags(SIZE_EXPAND_FILL);
add_child(button); add_child(button);
move_child(button, 0); move_child(button, 0);

View File

@ -22,11 +22,10 @@ SOFTWARE.
#include "paint_editor_plugin.h" #include "paint_editor_plugin.h"
#include "paint_window.h"
void PaintEditorPlugin::make_visible(const bool visible) { void PaintEditorPlugin::make_visible(const bool visible) {
/* window->set_visible(visible);
if editor_scene:
editor_scene.visible = visible
*/
} }
String PaintEditorPlugin::get_name() const { String PaintEditorPlugin::get_name() const {
@ -34,10 +33,7 @@ String PaintEditorPlugin::get_name() const {
} }
const Ref<Texture> PaintEditorPlugin::get_icon() const { const Ref<Texture> PaintEditorPlugin::get_icon() const {
// Must return some kind of Texture for the icon. return _icon;
//return get_editor_interface().get_base_control().get_icon("CanvasModulate", "EditorIcons")
return Ref<Texture>();
} }
bool PaintEditorPlugin::has_main_screen() const { bool PaintEditorPlugin::has_main_screen() const {
return true; return true;
@ -46,16 +42,12 @@ bool PaintEditorPlugin::has_main_screen() const {
PaintEditorPlugin::PaintEditorPlugin(EditorNode *p_node) { PaintEditorPlugin::PaintEditorPlugin(EditorNode *p_node) {
editor = p_node; editor = p_node;
/* window = memnew(PaintWindow);
editor_scene.name = "Editor"
if get_editor_interface().get_editor_viewport().has_node("Editor"): get_editor_interface()->get_editor_viewport()->add_child(window);
var n = get_editor_interface().get_editor_viewport().get_node("Editor") window->set_owner(get_editor_interface()->get_editor_viewport());
n.name = "EditorDel" make_visible(false);
n.queue_free() _icon = get_editor_interface()->get_base_control()->get_icon("CanvasModulate", "EditorIcons");
get_editor_interface().get_editor_viewport().add_child(editor_scene, true)
editor_scene.owner = get_editor_interface().get_editor_viewport()
make_visible(false)
*/
} }
PaintEditorPlugin::~PaintEditorPlugin() { PaintEditorPlugin::~PaintEditorPlugin() {

View File

@ -24,6 +24,10 @@ SOFTWARE.
*/ */
#include "editor/editor_plugin.h" #include "editor/editor_plugin.h"
#include "core/reference.h"
class PaintWindow;
class Texture;
class PaintEditorPlugin : public EditorPlugin { class PaintEditorPlugin : public EditorPlugin {
GDCLASS(PaintEditorPlugin, EditorPlugin); GDCLASS(PaintEditorPlugin, EditorPlugin);
@ -39,10 +43,12 @@ public:
EditorNode *editor; EditorNode *editor;
//var editor_scene = load("res://addons/Godoxel/Editor.tscn").instance() PaintWindow *window;
protected: protected:
static void _bind_methods(); static void _bind_methods();
Ref<Texture> _icon;
}; };
#endif #endif

View File

@ -24,29 +24,29 @@ SOFTWARE.
#include "paint_settings.h" #include "paint_settings.h"
void PaintTextInfo::_enter_tree() { void PaintSettings::_enter_tree() {
/* /*
canvas_outline = get_parent().find_node("CanvasOutline") canvas_outline = get_parent().find_node("CanvasOutline")
editor = get_parent() editor = get_parent()
*/ */
} }
void PaintTextInfo::_on_ColorPickerButton_color_changed(const Color &color) { void PaintSettings::_on_ColorPickerButton_color_changed(const Color &color) {
/* /*
canvas_outline.color = color canvas_outline.color = color
*/ */
} }
void PaintTextInfo::_on_CheckButton_toggled(const bool button_pressed) { void PaintSettings::_on_CheckButton_toggled(const bool button_pressed) {
/* /*
canvas_outline.visible = button_pressed canvas_outline.visible = button_pressed
*/ */
} }
void PaintTextInfo::_on_Ok_pressed() { void PaintSettings::_on_Ok_pressed() {
/* /*
hide() hide()
*/ */
} }
PaintTextInfo::PaintTextInfo() { PaintSettings::PaintSettings() {
/* /*
[gd_scene load_steps=2 format=2] [gd_scene load_steps=2 format=2]
@ -118,8 +118,8 @@ margin_bottom = 20.0
*/ */
} }
PaintTextInfo::~PaintTextInfo() { PaintSettings::~PaintSettings() {
} }
void PaintTextInfo::_bind_methods() { void PaintSettings::_bind_methods() {
} }

View File

@ -27,8 +27,8 @@ SOFTWARE.
#include "scene/gui/control.h" #include "scene/gui/control.h"
class PaintTextInfo : public Control { class PaintSettings : public Control {
GDCLASS(PaintTextInfo, Control); GDCLASS(PaintSettings, Control);
public: public:
void _enter_tree(); void _enter_tree();
@ -36,8 +36,8 @@ public:
void _on_CheckButton_toggled(const bool button_pressed); void _on_CheckButton_toggled(const bool button_pressed);
void _on_Ok_pressed(); void _on_Ok_pressed();
PaintTextInfo(); PaintSettings();
~PaintTextInfo(); ~PaintSettings();
protected: protected:
static void _bind_methods(); static void _bind_methods();

View File

@ -1,75 +0,0 @@
/*
Copyright (c) 2019 Flairieve
Copyright (c) 2020-2022 cobrapitz
Copyright (c) 2022 Péter Magyar
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
*/
#include "paint_text_info.h"
//TODO: To make reading the text easier, the text info with the longest text should have it's length applied to all the
//the other text infos
void PaintTextInfo::add_text_info(const String &text_name, Node *custom_node) {
/*
var last_text_info_child = null
var child_count = get_child_count()
if not child_count <= 0:
last_text_info_child = get_children()[get_children().size() - 1]
var label = Label.new()
label.name = text_name
label.rect_size = Vector2(size, 14)
if not last_text_info_child == null:
var x = last_text_info_child.rect_position.x
var y = last_text_info_child.rect_position.y
var temp_size = size
if child_count == 4:
x = 0
y = 20
temp_size = 0
label.rect_position = Vector2(x + temp_size, y)
if not custom_node == null:
label.add_child(custom_node)
add_child(label)
*/
}
void PaintTextInfo::update_text_info(const String &text_name, Node *text_value, Node *node, Node *node_target_value, Node *node_value) {
/*
var text_label = self.get_node(text_name)
if text_label == null:
return
if not node == null:
get_node(text_name).get_node(node).set(node_target_value, node_value)
if text_value == null:
text_label.text = "%s: %s" % [text_name, null]
else:
text_label.text = "%s: %s" % [text_name, String(text_value)]
*/
}
PaintTextInfo::PaintTextInfo() {
//var size = 240
}
PaintTextInfo::~PaintTextInfo() {
}
void PaintTextInfo::_bind_methods() {
}

View File

@ -1,46 +0,0 @@
#ifndef PAINT_TEXT_INFO_H
#define PAINT_TEXT_INFO_H
/*
Copyright (c) 2019 Flairieve
Copyright (c) 2020-2022 cobrapitz
Copyright (c) 2022 Péter Magyar
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
*/
#include "scene/gui/control.h"
class PaintTextInfo : public Control {
GDCLASS(PaintTextInfo, Control);
public:
void add_text_info(const String &text_name, Node *custom_node = nullptr);
void update_text_info(const String &text_name, Node *text_value = nullptr, Node *node = nullptr, Node *node_target_value = nullptr, Node *node_value = nullptr);
PaintTextInfo();
~PaintTextInfo();
protected:
static void _bind_methods();
//var size = 240
};
#endif

File diff suppressed because one or more lines are too long

View File

@ -32,7 +32,23 @@ SOFTWARE.
class PaintAction; class PaintAction;
class PaintCanvasLayer; class PaintCanvasLayer;
class PaintCanvas;
class InputEvent; class InputEvent;
class PaintCanvasDialog;
class PaintChangeGridSizeDialog;
class PaintLoadFileDialog;
class PaintSaveFileDialog;
class PaintSettings;
class RichTextLabel;
class PaintNavbar;
class PaintColorGrid;
class CheckButton;
class Label;
class HSlider;
class Control;
class Button;
class ColorPickerButton;
class VBoxContainer;
class PaintWindow : public Control { class PaintWindow : public Control {
GDCLASS(PaintWindow, Control); GDCLASS(PaintWindow, Control);
@ -149,6 +165,44 @@ public:
PaintWindow(); PaintWindow();
~PaintWindow(); ~PaintWindow();
PaintCanvasDialog *paint_canvas_dialog;
PaintChangeGridSizeDialog *paint_change_grid_size_dialog;
PaintLoadFileDialog *paint_load_file_dialog;
PaintSaveFileDialog *paint_save_file_dialog;
PaintSettings *paint_settings_dialog;
RichTextLabel *text_info;
PaintNavbar *navbar;
PaintColorGrid *color_grid;
CheckButton *lock_alpha_button;
Label *brush_size_label;
HSlider *brush_size_slider;
CheckButton *x_symmetry_button;
CheckButton *y_symmetry_button;
Control *paint_canvas_container;
PaintCanvas *paint_canvas;
Button *paint_tool_button;
Button *brush_tool_button;
Button *multi_tool_button;
Button *bucket_tool_button;
Button *rainbow_tool_button;
Button *line_tool_button;
Button *rect_tool_button;
Button *darken_tool_button;
Button *brighten_tool_button;
Button *color_picker_tool_button;
Button *cut_tool_button;
ColorPickerButton *color_picker_button;
VBoxContainer *layers_box_container;
Button *add_layer_button;
protected: protected:
static void _bind_methods(); static void _bind_methods();
/* /*

View File

@ -22,8 +22,8 @@ SOFTWARE.
#include "register_types.h" #include "register_types.h"
#ifdef TOOLS_ENABLED #ifdef TOOLS_ENABLED
#include "paint_editor_plugin.h"
#endif #endif
void register_paint_types() { void register_paint_types() {