summaryrefslogtreecommitdiff
path: root/tools/editor/icons/SCsub
diff options
context:
space:
mode:
Diffstat (limited to 'tools/editor/icons/SCsub')
-rw-r--r--tools/editor/icons/SCsub36
1 files changed, 31 insertions, 5 deletions
diff --git a/tools/editor/icons/SCsub b/tools/editor/icons/SCsub
index f3216b092d..bc104294cb 100644
--- a/tools/editor/icons/SCsub
+++ b/tools/editor/icons/SCsub
@@ -14,6 +14,8 @@ def make_editor_icons_action(target, source, env):
s.write("#include \"editor_scale.h\"\n\n")
s.write("#include \"scene/resources/theme.h\"\n\n")
+ hidpi_list=[]
+
for x in pixmaps:
x=str(x)
@@ -31,13 +33,36 @@ def make_editor_icons_action(target, source, env):
if (len(b)==1):
s.write(",")
- s.write("\n};\n\n\n");
+ s.write("\n};\n\n");
+
pngf.close();
+ var_str=os.path.basename(x)[:-4]+"_hidpi_png";
+ try:
+
+ pngf = open(os.path.dirname(x)+"/2x/"+os.path.basename(x), "rb")
+
+ s.write("static const unsigned char "+ var_str +"[]={\n");
+
+ b=pngf.read(1);
+ while(len(b)==1):
+ s.write(hex(ord(b)))
+ b=pngf.read(1);
+ if (len(b)==1):
+ s.write(",")
+
+ s.write("\n};\n\n\n");
+ hidpi_list.append(x)
+
+ except:
+ s.write("static const unsigned char* "+ var_str +"=NULL;\n\n\n");
+
+
+
- s.write("static Ref<ImageTexture> make_icon(const uint8_t* p_png) {\n")
+ s.write("static Ref<ImageTexture> make_icon(const uint8_t* p_png,const uint8_t* p_hidpi_png) {\n")
s.write("\tRef<ImageTexture> texture( memnew( ImageTexture ) );\n")
- s.write("\tImage img(p_png);\n")
- s.write("\tif (editor_is_hidpi()) img.expand_x2_hq2x();\n")
+ s.write("\tImage img((editor_is_hidpi()&&p_hidpi_png)?p_hidpi_png:p_png);\n")
+ s.write("\tif (editor_is_hidpi() && !p_hidpi_png) { img.convert(Image::FORMAT_RGBA); img.expand_x2_hq2x(); }\n")
s.write("\ttexture->create_from_image( img,ImageTexture::FLAG_FILTER );\n")
s.write("\treturn texture;\n")
s.write("}\n\n")
@@ -49,7 +74,8 @@ def make_editor_icons_action(target, source, env):
x=os.path.basename(str(x))
type=x[5:-4].title().replace("_","");
var_str=x[:-4]+"_png";
- s.write("\tp_theme->set_icon(\""+type+"\",\"EditorIcons\",make_icon("+var_str+"));\n");
+ var_str_hidpi=x[:-4]+"_hidpi_png";
+ s.write("\tp_theme->set_icon(\""+type+"\",\"EditorIcons\",make_icon("+var_str+","+var_str_hidpi+"));\n");
s.write("\n\n}\n\n");