mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2025-01-11 21:31:10 +01:00
Fully ported PaintLoadFlieDialog aswell.
This commit is contained in:
parent
8182d82135
commit
398af1a772
@ -24,12 +24,50 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "paint_load_file_dialog.h"
|
#include "paint_load_file_dialog.h"
|
||||||
|
|
||||||
|
#include "../paint_canvas.h"
|
||||||
|
#include "../paint_canvas_layer.h"
|
||||||
|
#include "../paint_window.h"
|
||||||
|
#include "../paint_utilities.h"
|
||||||
|
|
||||||
|
void PaintLoadFileDialog::load_img() {
|
||||||
|
Ref<Image> image;
|
||||||
|
image.instance();
|
||||||
|
|
||||||
|
if (image->load(file_path) != OK) {
|
||||||
|
ERR_FAIL_MSG("couldn't load image!");
|
||||||
|
}
|
||||||
|
|
||||||
|
PoolByteArray image_data = image->get_data();
|
||||||
|
Ref<PaintCanvasLayer> layer = window->add_new_layer();
|
||||||
|
|
||||||
|
int width = image->get_width();
|
||||||
|
int height = image->get_height();
|
||||||
|
|
||||||
|
if (canvas->get_canvas_width() < width) {
|
||||||
|
canvas->resize(width, canvas->get_canvas_height());
|
||||||
|
}
|
||||||
|
|
||||||
|
if (canvas->get_canvas_height() < height) {
|
||||||
|
canvas->resize(canvas->get_canvas_width(), height);
|
||||||
|
}
|
||||||
|
|
||||||
|
int iss = image_data.size() / 4;
|
||||||
|
for (int i = 0; i < iss; ++i) {
|
||||||
|
Color color = Color(image_data[i*4] / 255.0, image_data[i*4+1] / 255.0, image_data[i*4+2] / 255.0, image_data[i*4+3] / 255.0);
|
||||||
|
Vector2i pos = PaintUtilities::to_2D(i, image->get_width());
|
||||||
|
if (pos.x > layer->layer_width) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
layer->set_pixel(pos.x, pos.y, color);
|
||||||
|
}
|
||||||
|
|
||||||
|
layer->update_texture();
|
||||||
|
}
|
||||||
|
|
||||||
void PaintLoadFileDialog::_on_LoadFileDialog_file_selected(const String &path) {
|
void PaintLoadFileDialog::_on_LoadFileDialog_file_selected(const String &path) {
|
||||||
/*
|
file_path = path;
|
||||||
file_path = path
|
load_img();
|
||||||
#print("1ere")
|
|
||||||
load_img()
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
void PaintLoadFileDialog::_on_LoadFileDialog_confirmed() {
|
void PaintLoadFileDialog::_on_LoadFileDialog_confirmed() {
|
||||||
/*
|
/*
|
||||||
@ -38,87 +76,39 @@ void PaintLoadFileDialog::_on_LoadFileDialog_confirmed() {
|
|||||||
#load_img()
|
#load_img()
|
||||||
*/
|
*/
|
||||||
}
|
}
|
||||||
void PaintLoadFileDialog::load_img() {
|
|
||||||
/*
|
|
||||||
var image = Image.new()
|
|
||||||
if image.load(file_path) != OK:
|
|
||||||
print("couldn't load image!")
|
|
||||||
return
|
|
||||||
|
|
||||||
var image_data = image.get_data()
|
|
||||||
var layer: GELayer = owner.add_new_layer()
|
|
||||||
|
|
||||||
var width = image.get_width()
|
|
||||||
var height = image.get_height()
|
|
||||||
|
|
||||||
if owner.paint_canvas.canvas_width < width:
|
|
||||||
owner.paint_canvas.resize(width, owner.paint_canvas.canvas_height)
|
|
||||||
|
|
||||||
if owner.paint_canvas.canvas_height < height:
|
|
||||||
owner.paint_canvas.resize(owner.paint_canvas.canvas_width, height)
|
|
||||||
|
|
||||||
for i in range(image_data.size() / 4):
|
|
||||||
var color = Color(image_data[i*4] / 255.0, image_data[i*4+1] / 255.0, image_data[i*4+2] / 255.0, image_data[i*4+3] / 255.0)
|
|
||||||
var pos = GEUtils.to_2D(i, image.get_width())
|
|
||||||
if pos.x > layer.layer_width:
|
|
||||||
continue
|
|
||||||
|
|
||||||
layer.set_pixel(pos.x, pos.y, color)
|
|
||||||
layer.update_texture()
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
void PaintLoadFileDialog::_on_LoadFileDialog_about_to_show() {
|
void PaintLoadFileDialog::_on_LoadFileDialog_about_to_show() {
|
||||||
/*
|
invalidate();
|
||||||
invalidate()
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
void PaintLoadFileDialog::_on_LoadFileDialog_visibility_changed() {
|
void PaintLoadFileDialog::_on_LoadFileDialog_visibility_changed() {
|
||||||
/*
|
invalidate();
|
||||||
invalidate()
|
}
|
||||||
*/
|
|
||||||
|
void PaintLoadFileDialog::_notification(int p_what) {
|
||||||
|
switch (p_what) {
|
||||||
|
case NOTIFICATION_POSTINITIALIZE: {
|
||||||
|
connect("file_selected", this, "_on_LoadFileDialog_file_selected");
|
||||||
|
connect("about_to_show", this, "_on_LoadFileDialog_about_to_show");
|
||||||
|
connect("confirmed", this, "_on_LoadFileDialog_confirmed");
|
||||||
|
connect("visibility_changed", this, "_on_LoadFileDialog_visibility_changed");
|
||||||
|
} break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
PaintLoadFileDialog::PaintLoadFileDialog() {
|
PaintLoadFileDialog::PaintLoadFileDialog() {
|
||||||
//var file_path = ""
|
add_filter("*.png ; PNG Images");
|
||||||
|
set_mode(FileDialog::MODE_OPEN_FILE);
|
||||||
/*
|
set_show_hidden_files(true);
|
||||||
get_line_edit().connect("text_entered", self, "_on_LineEdit_text_entered")
|
set_resizable(true);
|
||||||
invalidate()
|
set_size(Size2(600, 400));
|
||||||
clear_filters()
|
set_title("Open a File");
|
||||||
add_filter("*.png ; PNG Images")
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
|
|
||||||
[gd_scene load_steps=2 format=2]
|
|
||||||
|
|
||||||
[sub_resource type="GDScript" id=1]
|
|
||||||
script/source = "extends ConfirmationDialog
|
|
||||||
|
|
||||||
func _ready():
|
|
||||||
get_ok().connect(\"pressed\", self, \"hide\")
|
|
||||||
get_cancel().connect(\"pressed\", self, \"hide\")
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
"
|
|
||||||
|
|
||||||
[node name="LoadFileDialog" type="FileDialog"]
|
|
||||||
margin_right = 604.0
|
|
||||||
margin_bottom = 367.0
|
|
||||||
window_title = "Open a File"
|
|
||||||
mode = 0
|
|
||||||
access = 2
|
|
||||||
current_dir = "/Projects/BitBucket/GraphicsEditor"
|
|
||||||
current_path = "/Projects/BitBucket/GraphicsEditor/"
|
|
||||||
script = SubResource( 1 )
|
|
||||||
|
|
||||||
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
PaintLoadFileDialog::~PaintLoadFileDialog() {
|
PaintLoadFileDialog::~PaintLoadFileDialog() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void PaintLoadFileDialog::_bind_methods() {
|
void PaintLoadFileDialog::_bind_methods() {
|
||||||
|
ClassDB::bind_method(D_METHOD("_on_LoadFileDialog_file_selected", "path"), &PaintLoadFileDialog::_on_LoadFileDialog_file_selected);
|
||||||
|
ClassDB::bind_method(D_METHOD("_on_LoadFileDialog_confirmed"), &PaintLoadFileDialog::_on_LoadFileDialog_confirmed);
|
||||||
|
ClassDB::bind_method(D_METHOD("_on_LoadFileDialog_about_to_show"), &PaintLoadFileDialog::_on_LoadFileDialog_about_to_show);
|
||||||
|
ClassDB::bind_method(D_METHOD("_on_LoadFileDialog_visibility_changed"), &PaintLoadFileDialog::_on_LoadFileDialog_visibility_changed);
|
||||||
}
|
}
|
||||||
|
@ -27,24 +27,31 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "scene/gui/file_dialog.h"
|
#include "scene/gui/file_dialog.h"
|
||||||
|
|
||||||
|
class PaintCanvas;
|
||||||
|
class PaintWindow;
|
||||||
|
|
||||||
class PaintLoadFileDialog : public FileDialog {
|
class PaintLoadFileDialog : public FileDialog {
|
||||||
GDCLASS(PaintLoadFileDialog, FileDialog);
|
GDCLASS(PaintLoadFileDialog, FileDialog);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
void load_img();
|
||||||
|
|
||||||
void _on_LoadFileDialog_file_selected(const String &path);
|
void _on_LoadFileDialog_file_selected(const String &path);
|
||||||
void _on_LoadFileDialog_confirmed();
|
void _on_LoadFileDialog_confirmed();
|
||||||
void load_img();
|
|
||||||
void _on_LoadFileDialog_about_to_show();
|
void _on_LoadFileDialog_about_to_show();
|
||||||
void _on_LoadFileDialog_visibility_changed();
|
void _on_LoadFileDialog_visibility_changed();
|
||||||
|
|
||||||
PaintLoadFileDialog();
|
PaintLoadFileDialog();
|
||||||
~PaintLoadFileDialog();
|
~PaintLoadFileDialog();
|
||||||
|
|
||||||
protected:
|
String file_path;
|
||||||
static void _bind_methods();
|
|
||||||
|
|
||||||
//var file_path = ""
|
PaintCanvas *canvas;
|
||||||
//var canvas: GECanvas
|
PaintWindow *window;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
void _notification(int p_what);
|
||||||
|
static void _bind_methods();
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -1415,11 +1415,15 @@ PaintWindow::PaintWindow() {
|
|||||||
|
|
||||||
//PaintLoadFileDialog
|
//PaintLoadFileDialog
|
||||||
paint_load_file_dialog = memnew(PaintLoadFileDialog);
|
paint_load_file_dialog = memnew(PaintLoadFileDialog);
|
||||||
|
paint_load_file_dialog->canvas = paint_canvas;
|
||||||
|
paint_load_file_dialog->window = this;
|
||||||
|
paint_load_file_dialog->set_size(Size2(600, 400));
|
||||||
add_child(paint_load_file_dialog);
|
add_child(paint_load_file_dialog);
|
||||||
|
|
||||||
//PaintSaveFileDialog
|
//PaintSaveFileDialog
|
||||||
paint_save_file_dialog = memnew(PaintSaveFileDialog);
|
paint_save_file_dialog = memnew(PaintSaveFileDialog);
|
||||||
paint_save_file_dialog->canvas = paint_canvas;
|
paint_save_file_dialog->canvas = paint_canvas;
|
||||||
|
paint_load_file_dialog->set_size(Size2(600, 400));
|
||||||
add_child(paint_save_file_dialog);
|
add_child(paint_save_file_dialog);
|
||||||
|
|
||||||
//PaintSettings
|
//PaintSettings
|
||||||
|
Loading…
Reference in New Issue
Block a user