]> git.rm.cloudns.org Git - xonotic/xonotic-data.pk3dir.git/commitdiff
Make possible to move the zoomed-in screenshot on mouse drag
authorterencehill <piuntn@gmail.com>
Tue, 7 Jun 2011 22:07:15 +0000 (00:07 +0200)
committerterencehill <piuntn@gmail.com>
Tue, 7 Jun 2011 22:07:15 +0000 (00:07 +0200)
qcsrc/menu/item/image.c
qcsrc/menu/xonotic/screenshotimage.c

index 1ae925538d937e6fdb68866f143c3e52cf170d7f..901001b6582f4ea04b0f1a46cb984e06b9bdd1d2 100644 (file)
@@ -6,10 +6,15 @@ CLASS(Image) EXTENDS(Item)
        METHOD(Image, resizeNotify, void(entity, vector, vector, vector, vector))
        METHOD(Image, updateAspect, void(entity))
        METHOD(Image, setZoom, void(entity, float))
+       METHOD(Image, startZoomMove, float(entity, vector))
+       METHOD(Image, zoomMove, float(entity, vector))
        ATTRIB(Image, src, string, string_null)
        ATTRIB(Image, color, vector, '1 1 1')
        ATTRIB(Image, forcedAspect, float, 0)
        ATTRIB(Image, zoomFactor, float, 1)
+       ATTRIB(Image, zoomOffset, vector, '0.5 0.5 0')
+       ATTRIB(Image, start_zoomOffset, vector, '0 0 0')
+       ATTRIB(Image, start_coords, vector, '0 0 0')
        ATTRIB(Image, imgOrigin, vector, '0 0 0')
        ATTRIB(Image, imgSize, vector, '0 0 0')
 ENDCLASS(Image)
@@ -23,6 +28,7 @@ string Image_toString(entity me)
 void Image_configureImage(entity me, string path)
 {
        me.src = path;
+       me.zoomOffset = '0.5 0.5 0';
        me.zoomFactor = 1;
 }
 void Image_draw(entity me)
@@ -64,9 +70,35 @@ void Image_updateAspect(entity me)
                        me.imgSize = eX + eY * (me.size_x / (asp * me.size_y));
                }
                if (me.zoomFactor)
+               {
+                       if (me.zoomFactor > 1)
+                       {
+                               me.zoomOffset_x = bound(0, me.zoomOffset_x, 1);
+                               me.zoomOffset_y = bound(0, me.zoomOffset_y, 1);
+                       }
                        me.imgSize = me.imgSize * me.zoomFactor;
-               me.imgOrigin = '0.5 0.5 0' - 0.5 * me.imgSize;
+               }
+               me.imgOrigin_x = 0.5 - me.zoomOffset_x * me.imgSize_x;
+               me.imgOrigin_y = 0.5 - me.zoomOffset_y * me.imgSize_y;
+       }
+}
+float Image_startZoomMove(entity me, vector coords)
+{
+       if (me.zoomFactor > 1)
+       {
+               me.start_zoomOffset = me.zoomOffset;
+               me.start_coords = coords;
+       }
+       return 1;
+}
+float Image_zoomMove(entity me, vector coords)
+{
+       if (me.zoomFactor > 1)
+       {
+               me.zoomOffset = me.start_zoomOffset + (me.start_coords - coords)*(1/me.zoomFactor);
+               me.updateAspect(me);
        }
+       return 1;
 }
 void Image_setZoom(entity me, float z)
 {
@@ -77,6 +109,8 @@ void Image_setZoom(entity me, float z)
        else
                me.zoomFactor *= z;
        me.zoomFactor = bound(1/16, me.zoomFactor, 16);
+       if (me.zoomFactor <= 1)
+               me.zoomOffset = '0.5 0.5 0';
        me.updateAspect(me);
 }
 void Image_resizeNotify(entity me, vector relOrigin, vector relSize, vector absOrigin, vector absSize)
index b621c0f9dd4ae06623e8939fdb8295df38255c87..77a9a9fbfc805f3551920845805bdda7f47b0088 100644 (file)
@@ -2,6 +2,9 @@
 CLASS(XonoticScreenshotImage) EXTENDS(Image)
        METHOD(XonoticScreenshotImage, configureXonoticScreenshotImage, void(entity, string))
        METHOD(XonoticScreenshotImage, draw, void(entity))
+       ATTRIB(XonoticScreenshotImage, focusable, float, 1) // mousePress and mouseDrag work only if focusable is set
+       METHOD(XonoticScreenshotImage, mousePress, float(entity, vector))
+       METHOD(XonoticScreenshotImage, mouseDrag, float(entity, vector))
        METHOD(XonoticScreenshotImage, resizeNotify, void(entity, vector, vector, vector, vector))
        ATTRIB(XonoticScreenshotImage, realFontSize, vector, '0 0 0')
        ATTRIB(XonoticScreenshotImage, fontSize, float, SKINFONTSIZE_NORMAL)
@@ -32,6 +35,16 @@ void XonoticScreenshotImage_configureXonoticScreenshotImage(entity me, string th
        me.screenshotTitle = strzone(substring(me.src, 13, strlen(theImage) - 13)); //strip "/screenshots/"
 }
 
+float XonoticScreenshotImage_mousePress(entity me, vector coords)
+{
+       return me.startZoomMove(me, coords);
+}
+
+float XonoticScreenshotImage_mouseDrag(entity me, vector coords)
+{
+       return me.zoomMove(me, coords);
+}
+
 void XonoticScreenshotImage_draw(entity me)
 {
        if (me.src != "")