Add functions to image to load a PNG or JPG from a buffer, closes #4024
This commit is contained in:
parent
03823f12c5
commit
c9d88fd8e8
2 changed files with 40 additions and 0 deletions
|
@ -2287,6 +2287,9 @@ void Image::_bind_methods() {
|
||||||
ClassDB::bind_method(D_METHOD("set_pixel", "x", "y", "color"), &Image::set_pixel);
|
ClassDB::bind_method(D_METHOD("set_pixel", "x", "y", "color"), &Image::set_pixel);
|
||||||
ClassDB::bind_method(D_METHOD("get_pixel", "x", "y"), &Image::get_pixel);
|
ClassDB::bind_method(D_METHOD("get_pixel", "x", "y"), &Image::get_pixel);
|
||||||
|
|
||||||
|
ClassDB::bind_method(D_METHOD("load_png_from_buffer", "buffer"), &Image::load_png_from_buffer);
|
||||||
|
ClassDB::bind_method(D_METHOD("load_jpg_from_buffer", "buffer"), &Image::load_jpg_from_buffer);
|
||||||
|
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::DICTIONARY, "data", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_STORAGE), "_set_data", "_get_data");
|
ADD_PROPERTY(PropertyInfo(Variant::DICTIONARY, "data", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_STORAGE), "_set_data", "_get_data");
|
||||||
|
|
||||||
BIND_ENUM_CONSTANT(FORMAT_L8); //luminance
|
BIND_ENUM_CONSTANT(FORMAT_L8); //luminance
|
||||||
|
@ -2505,6 +2508,40 @@ String Image::get_format_name(Format p_format) {
|
||||||
return format_names[p_format];
|
return format_names[p_format];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Error Image::load_png_from_buffer(const PoolVector<uint8_t> &p_array) {
|
||||||
|
|
||||||
|
int buffer_size = p_array.size();
|
||||||
|
|
||||||
|
ERR_FAIL_COND_V(buffer_size == 0, ERR_INVALID_PARAMETER);
|
||||||
|
ERR_FAIL_COND_V(!_png_mem_loader_func, ERR_INVALID_PARAMETER);
|
||||||
|
|
||||||
|
PoolVector<uint8_t>::Read r = p_array.read();
|
||||||
|
|
||||||
|
Ref<Image> image = _png_mem_loader_func(r.ptr(), buffer_size);
|
||||||
|
ERR_FAIL_COND_V(!image.is_valid(), ERR_PARSE_ERROR);
|
||||||
|
|
||||||
|
copy_internals_from(image);
|
||||||
|
|
||||||
|
return OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
Error Image::load_jpg_from_buffer(const PoolVector<uint8_t> &p_array) {
|
||||||
|
|
||||||
|
int buffer_size = p_array.size();
|
||||||
|
|
||||||
|
ERR_FAIL_COND_V(buffer_size == 0, ERR_INVALID_PARAMETER);
|
||||||
|
ERR_FAIL_COND_V(!_jpg_mem_loader_func, ERR_INVALID_PARAMETER);
|
||||||
|
|
||||||
|
PoolVector<uint8_t>::Read r = p_array.read();
|
||||||
|
|
||||||
|
Ref<Image> image = _jpg_mem_loader_func(r.ptr(), buffer_size);
|
||||||
|
ERR_FAIL_COND_V(!image.is_valid(), ERR_PARSE_ERROR);
|
||||||
|
|
||||||
|
copy_internals_from(image);
|
||||||
|
|
||||||
|
return OK;
|
||||||
|
}
|
||||||
|
|
||||||
Image::Image(const uint8_t *p_mem_png_jpg, int p_len) {
|
Image::Image(const uint8_t *p_mem_png_jpg, int p_len) {
|
||||||
|
|
||||||
width = 0;
|
width = 0;
|
||||||
|
|
|
@ -296,6 +296,9 @@ public:
|
||||||
static void set_compress_bc_func(void (*p_compress_func)(Image *, CompressSource));
|
static void set_compress_bc_func(void (*p_compress_func)(Image *, CompressSource));
|
||||||
static String get_format_name(Format p_format);
|
static String get_format_name(Format p_format);
|
||||||
|
|
||||||
|
Error load_png_from_buffer(const PoolVector<uint8_t> &p_array);
|
||||||
|
Error load_jpg_from_buffer(const PoolVector<uint8_t> &p_array);
|
||||||
|
|
||||||
Image(const uint8_t *p_mem_png_jpg, int p_len = -1);
|
Image(const uint8_t *p_mem_png_jpg, int p_len = -1);
|
||||||
Image(const char **p_xpm);
|
Image(const char **p_xpm);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue