diff --git a/extensions/community/PointAndOrbit.json b/extensions/community/PointAndOrbit.json index dd93af654..8980fe5cb 100644 --- a/extensions/community/PointAndOrbit.json +++ b/extensions/community/PointAndOrbit.json @@ -1,15 +1,29 @@ { "author": "", "category": "Movement", - "description": "# User can\n- Use the extension action multi times.\n- Point object toward position.\n- Orbit object around position.\n- Set the distance to orbit around.\n- Set the pointing speed.\n\n# Example\n![](https://i.imgur.com/N2KtaMT.png)", "extensionNamespace": "", "fullName": "Point and Orbit", "helpPath": "", "iconUrl": "", "name": "PointAndOrbit", "previewIconUrl": "https://resources.gdevelop-app.com/assets/Icons/arrow-bottom-right-bold-outline.svg", - "shortDescription": "Point an object toward a position and Orbit around a position.", - "version": "1.0.0", + "shortDescription": "Point and orbit an object toward a position or angle.", + "version": "1.1.0", + "description": [ + "Move an object in a circle around a specific point while pointing the moving object away from the center of the circle.", + "This feature is useful in games for weapons or targeting indicators that move around a player character.", + "Orbit distance and rotation speed can be changed easily.", + "", + "The target position action can be used to follow the direction of the cursor.", + "The target angle action can be used to follow hte direction of a gamepad stick", + "", + "# Example", + "![](https://i.imgur.com/N2KtaMT.png)" + ], + "origin": { + "identifier": "PointAndOrbit", + "name": "gdevelop-extension-store" + }, "tags": [ "point", "orbit", @@ -17,17 +31,16 @@ "around" ], "authorIds": [ - "IRIhkkTTl2UHhfjrLTTH5GYwkYu1" + "IRIhkkTTl2UHhfjrLTTH5GYwkYu1", + "gqDaZjCfevOOxBYkK6zlhtZnXCg1" ], "dependencies": [], "eventsFunctions": [ { - "description": "Point and Orbit an object.", - "fullName": "Point and Orbit", + "description": "Point and Orbit an object toward a position.", + "fullName": "Point and Orbit toward a position", "functionType": "Action", - "group": "", "name": "PointAndOrbit", - "private": false, "sentence": "Point _PARAM1_ at _PARAM5_ Xpos, _PARAM6_ Ypos, at _PARAM7_ pointing speed, and orbit around _PARAM2_ Xpos, _PARAM3_ Ypos, at _PARAM4_ distance", "events": [ { @@ -36,24 +49,26 @@ "actions": [ { "type": { - "value": "MettreAutourPos" + "value": "ModVarScene" }, "parameters": [ - "Gun", - "GetArgumentAsNumber(\"OrbitXpos\")", - "GetArgumentAsNumber(\"OrbitYpos\")", - "GetArgumentAsNumber(\"OrbitDistance\")", - "AngleBetweenPositions(GetArgumentAsNumber(\"OrbitXpos\"),GetArgumentAsNumber(\"OrbitYpos\"),GetArgumentAsNumber(\"PointXpos\"),GetArgumentAsNumber(\"PointYpos\"))" + "__PointAndOrbit.TargetAngle", + "=", + "AngleBetweenPositions(OrbitXpos, OrbitYpos, PointXpos, PointYpos)" ] }, { "type": { - "value": "RotateTowardAngle" + "value": "PointAndOrbit::PointAndOrbitAngle" }, "parameters": [ + "", "Gun", - "AngleBetweenPositions(GetArgumentAsNumber(\"OrbitXpos\"),GetArgumentAsNumber(\"OrbitYpos\"),GetArgumentAsNumber(\"PointXpos\"),GetArgumentAsNumber(\"PointYpos\"))", - "GetArgumentAsNumber(\"PointSpeed\")", + "OrbitXpos", + "OrbitYpos", + "OrbitDistance", + "Variable(__PointAndOrbit.TargetAngle)", + "PointSpeed", "" ] } @@ -62,73 +77,188 @@ ], "parameters": [ { - "codeOnly": false, - "defaultValue": "", "description": "Gun object", "longDescription": "The object that is going to orbit and rotate.", "name": "Gun", - "optional": false, - "supplementaryInformation": "", "type": "objectList" }, { - "codeOnly": false, - "defaultValue": "", "description": "Orbit around this X position", "longDescription": "Gun object will orbit around this X position.", "name": "OrbitXpos", - "optional": false, - "supplementaryInformation": "", "type": "expression" }, { - "codeOnly": false, - "defaultValue": "", "description": "Orbit around this Y position", "longDescription": "Gun object will orbit around this Y position.", "name": "OrbitYpos", - "optional": false, - "supplementaryInformation": "", "type": "expression" }, { - "codeOnly": false, - "defaultValue": "", "description": "Orbit distance (in pixels)", "longDescription": "Distance between the Gun object and the Orbit positions X and Y. \nExample: 50 .", "name": "OrbitDistance", - "optional": false, - "supplementaryInformation": "", "type": "expression" }, { - "codeOnly": false, - "defaultValue": "", "description": "Point to this X position", "longDescription": "Point the gun object to this Xposition.", "name": "PointXpos", - "optional": false, - "supplementaryInformation": "", "type": "expression" }, { - "codeOnly": false, - "defaultValue": "", "description": "Point to this Y position", "longDescription": "Point the gun object to this Yposition.", "name": "PointYpos", - "optional": false, - "supplementaryInformation": "", "type": "expression" }, { - "codeOnly": false, - "defaultValue": "", "description": "Pointing speed (in deg/second)", "longDescription": "Set to 0 for an immediate pointing.", "name": "PointSpeed", - "optional": false, - "supplementaryInformation": "", + "type": "expression" + } + ], + "objectGroups": [] + }, + { + "description": "Point and Orbit an object toward an angle.", + "fullName": "Point and Orbit toward an angle", + "functionType": "Action", + "name": "PointAndOrbitAngle", + "sentence": "Point _PARAM1_ towards _PARAM5_ degrees at _PARAM6_ pointing speed, and orbit around _PARAM2_ Xpos, _PARAM3_ Ypos, at _PARAM4_ distance", + "events": [ + { + "colorB": 228, + "colorG": 176, + "colorR": 74, + "creationTime": 0, + "name": "Determine the orbit angle for the next frame (using the shortest path)", + "source": "", + "type": "BuiltinCommonInstructions::Group", + "events": [ + { + "type": "BuiltinCommonInstructions::Standard", + "conditions": [ + { + "type": { + "value": "BuiltinCommonInstructions::CompareNumbers" + }, + "parameters": [ + "mod(180 + TargetAngle - Gun.Angle(), 360)", + "<", + "180" + ] + } + ], + "actions": [ + { + "type": { + "value": "ModVarScene" + }, + "parameters": [ + "__PointAndOrbit.NextFrameAngle", + "=", + "Gun.Angle() - (PointSpeed * TimeDelta())" + ] + } + ] + }, + { + "type": "BuiltinCommonInstructions::Standard", + "conditions": [ + { + "type": { + "value": "BuiltinCommonInstructions::CompareNumbers" + }, + "parameters": [ + "mod(180 + Gun.Angle() - TargetAngle, 360)", + "<", + "180" + ] + } + ], + "actions": [ + { + "type": { + "value": "ModVarScene" + }, + "parameters": [ + "__PointAndOrbit.NextFrameAngle", + "=", + "Gun.Angle() + (PointSpeed * TimeDelta())" + ] + } + ] + } + ], + "parameters": [] + }, + { + "type": "BuiltinCommonInstructions::Standard", + "conditions": [], + "actions": [ + { + "type": { + "value": "MettreAutourPos" + }, + "parameters": [ + "Gun", + "OrbitXpos", + "OrbitYpos", + "OrbitDistance", + "Variable(__PointAndOrbit.NextFrameAngle)" + ] + }, + { + "type": { + "value": "RotateTowardAngle" + }, + "parameters": [ + "Gun", + "TargetAngle", + "PointSpeed", + "" + ] + } + ] + } + ], + "parameters": [ + { + "description": "Gun object", + "longDescription": "The object that is going to orbit and rotate.", + "name": "Gun", + "type": "objectList" + }, + { + "description": "Orbit around this X position", + "longDescription": "Gun object will orbit around this X position.", + "name": "OrbitXpos", + "type": "expression" + }, + { + "description": "Orbit around this Y position", + "longDescription": "Gun object will orbit around this Y position.", + "name": "OrbitYpos", + "type": "expression" + }, + { + "description": "Orbit distance (in pixels)", + "longDescription": "Distance between the Gun object and the Orbit positions X and Y. \nExample: 50 .", + "name": "OrbitDistance", + "type": "expression" + }, + { + "description": "Angle", + "longDescription": "Point the gun object to this angle", + "name": "TargetAngle", + "type": "expression" + }, + { + "description": "Pointing speed (in deg/second)", + "longDescription": "Set to 0 for an immediate pointing.", + "name": "PointSpeed", "type": "expression" } ],