]> de.git.xonotic.org Git - xonotic/xonotic-data.pk3dir.git/commitdiff
drawpic_aspect wrapper for drawpic
authorFruitieX <rasse@rasse-lappy.localdomain>
Thu, 17 Jun 2010 16:10:09 +0000 (19:10 +0300)
committerFruitieX <rasse@rasse-lappy.localdomain>
Thu, 17 Jun 2010 16:10:09 +0000 (19:10 +0300)
qcsrc/client/hud.qc

index da19f03e33bca828ecc4a5d3b01a43d2da94d1d4..f8c01ec986cc7ddc928e83e8718331f6639ce005 100644 (file)
@@ -75,9 +75,30 @@ void draw_BorderPicture(vector theOrigin, string pic, vector theSize, vector the
        }
 }
 
+// drawpic wrapper to draw an image as large as possible with preserved aspect ratio into a box
+void drawpic_aspect(vector pos, string pic, vector sz, vector color, float alpha, float drawflag) {
+       vector imgsize;
+       imgsize = drawgetimagesize(pic);
+       float imgaspect;
+       imgaspect = imgsize_x/imgsize_y;
+
+       vector oldsz;
+       oldsz = sz;
+       float aspect;
+       aspect = sz_x/sz_y;
+
+       if(aspect > imgaspect) {
+               sz_x = sz_y * imgaspect;
+               drawpic(pos + eX * (oldsz_x - sz_x) * 0.5, pic, sz, color, alpha, drawflag);
+       } else {
+               sz_y = sz_x / imgaspect; 
+               drawpic(pos + eY * (oldsz_y - sz_y) * 0.5, pic, sz, color, alpha, drawflag);
+       }
+}
+
 // draw HUD element with image from gfx/hud/hud_skin/foo.tga if it exists, otherwise gfx/hud/default/foo.tga
 void drawpic_skin(vector pos, string pic, vector sz, vector color, float alpha, float drawflag) {
-       drawpic(pos, strcat("gfx/hud/", cvar_string("hud_skin"), "/", pic), sz, color, alpha, drawflag);
+       drawpic_aspect(pos, strcat("gfx/hud/", cvar_string("hud_skin"), "/", pic), sz, color, alpha, drawflag);
 }
 
 void drawpic_skin_expanding(vector pos, string pic, vector sz, vector rgb, float alpha, float flag, float fadelerp) {