]> git.rm.cloudns.org Git - xonotic/xonotic-data.pk3dir.git/commitdiff
Add damageforcescale as an editable object property
authorMircea Kitsune <sonichedgehog_hyperblast00@yahoo.com>
Wed, 26 Oct 2011 12:10:52 +0000 (15:10 +0300)
committerMircea Kitsune <sonichedgehog_hyperblast00@yahoo.com>
Wed, 26 Oct 2011 12:10:52 +0000 (15:10 +0300)
defaultXonotic.cfg
qcsrc/menu/xonotic/dialog_sandboxtools.c
qcsrc/server/mutators/sandbox.qc

index 6e8433174b1ec2e35cb932029de101b69e676bee..4b9b5a45a4e49a23ec32e419f9e05760a37d9087 100644 (file)
@@ -554,6 +554,7 @@ set menu_sandbox_edit_color_glow "1 1 1"
 set menu_sandbox_edit_frame 0
 set menu_sandbox_edit_scale 1
 set menu_sandbox_edit_physics 0
+set menu_sandbox_edit_force 0
 
 alias menu_showsandboxtools "menu_cmd directmenu SandboxTools"
 bind f7 menu_showsandboxtools
index b181f8c27c1d2c92b170d60592ac59421ca931ce..39cb997682b28c7733cc62c653e5abfb7886f0c8 100644 (file)
@@ -53,6 +53,9 @@ void XonoticSandboxToolsDialog_fill(entity me)
                me.TD(me, 1, 0.5, e = makeXonoticRadioButton(1, "menu_sandbox_edit_physics", "0", _("Static")));
                me.TD(me, 1, 0.5, e = makeXonoticRadioButton(1, "menu_sandbox_edit_physics", "1", _("Movable")));
                me.TD(me, 1, 0.5, e = makeXonoticRadioButton(1, "menu_sandbox_edit_physics", "2", _("Physical")));
+       me.TR(me);
+               me.TD(me, 1, 0.5, makeXonoticCommandButton(_("Set force:"), '0 0 0', "sandbox edit_object force $menu_sandbox_edit_force", 0));
+               me.TD(me, 1, 1.5, e = makeXonoticSlider(0, 10, 0.5, "menu_sandbox_edit_force"));
 
        me.gotoRC(me, me.rows - 1, 0);
                me.TD(me, 1, me.columns, e = makeXonoticButton(_("OK"), '0 0 0'));
index b1292263d3642c0af1efc079be271788aa7f7e7a..a0d4c56dfea6ba1e9941393f8de47346ee97826f 100644 (file)
@@ -21,6 +21,7 @@ entity sandbox_SpawnObject()
        e.realowner = self;
        e.classname = "object";
        e.takedamage = DAMAGE_AIM;
+       e.damageforcescale = 0;
        e.solid = SOLID_BBOX; // SOLID_BSP would be best, but can lag the server badly
        e.movetype = MOVETYPE_TOSS;
        e.frame = 0;
@@ -68,6 +69,7 @@ MUTATOR_HOOKFUNCTION(sandbox_PlayerCommand)
                                print_to(self, "^3frame value ^7- object animation frame, for self-animated models");
                                print_to(self, "^3scale value ^7- changes object scale. 0.5 is half size and 2 is double size");
                                print_to(self, "^3physics value ^7- object physics, 0 = static, 1 = movable, 2 = physical");
+                               print_to(self, "^force value ^7- amount of force applied to objects that are shot");
                                print_to(self, "^7The ^1drag object ^7key can be used to grab and carry objects. Players can only grab their own objects");
                                return TRUE;
 
@@ -157,6 +159,7 @@ MUTATOR_HOOKFUNCTION(sandbox_PlayerCommand)
                                        self.object_clipboard = strcat(self.object_clipboard, ftos(e.frame), " ");
                                        self.object_clipboard = strcat(self.object_clipboard, ftos(e.scale), " ");
                                        self.object_clipboard = strcat(self.object_clipboard, ftos(e.movetype), " ");
+                                       self.object_clipboard = strcat(self.object_clipboard, ftos(e.damageforcescale), " ");
 
                                        self.object_clipboard = strzone(self.object_clipboard);
                                        print_to(self, "Object copied to clipboard");
@@ -188,6 +191,7 @@ MUTATOR_HOOKFUNCTION(sandbox_PlayerCommand)
                                e.frame = stof(argv(5));
                                e.scale = stof(argv(6));        if(self.scale)  setsize(e, e.mins * e.scale, e.maxs * e.scale); // adapt bounding box size to model size
                                e.movetype = stof(argv(7));
+                               e.damageforcescale = stof(argv(8));
 
                                print_to(self, "Object pasted");
                                if(autocvar_g_sandbox_info)
@@ -244,6 +248,9 @@ MUTATOR_HOOKFUNCTION(sandbox_PlayerCommand)
                                                                        break;
                                                        }
                                                        break;
+                                               case "force":
+                                                       e.damageforcescale = stof(argv(3));
+                                                       break;
                                                default:
                                                        print_to(self, "WARNING: Invalid object property. For usage information, type 'sandbox help'");
                                                        break;