Shooting Projectiles: различия между версиями
Patarakin (обсуждение | вклад) м (1 версия импортирована) |
Patarakin (обсуждение | вклад) |
||
Строка 1: | Строка 1: | ||
This tutorial explains how to create the effect of shooting, launching, or throwing an object. The code in this article does not simulate velocity or parabolic motion, but to a projectile that, after the initial force, is not acted upon by any traditional force (gravity, wind, etc.), though it may be obstructed by walls or targets. | This tutorial explains how to create the effect of shooting, launching, or throwing an object. The code in this article does not simulate velocity or parabolic motion, but to a projectile that, after the initial force, is not acted upon by any traditional force (gravity, wind, etc.), though it may be obstructed by walls or targets. | ||
Строка 161: | Строка 160: | ||
[[Category:Scripting Tutorials]] | [[Category:Scripting Tutorials]] | ||
Версия 11:13, 29 августа 2022
This tutorial explains how to create the effect of shooting, launching, or throwing an object. The code in this article does not simulate velocity or parabolic motion, but to a projectile that, after the initial force, is not acted upon by any traditional force (gravity, wind, etc.), though it may be obstructed by walls or targets.
In each example, the projectile shoots when the space key is pressed, but the trigger can be any Boolean Block.
Two sprites, no cloning
These scripts require two sprites; a player sprite and a projectile sprite. No cloning is used.
Semi-Automatic
This script requires the player to release the trigger button before firing again. This reduces the rate of fire:
when gf clicked // in the player's character sprite forever wait until <key (space v) pressed?> broadcast (shoot v) and wait wait until <not <key (space v) pressed?>> // the player can only shoot once at a time end when I receive [shoot v] //in the projectile sprite go to (The player v) //start at the player show repeat until <<touching (intended target/s v)?> or <touching (edge v)?>> //moves the sprite until it is touching something that will make it go away move (10) steps end hide
Automatic
This script allows the player to simply hold the trigger button for continuous fire:
when gf clicked //in player's sprite forever wait until <key (space v) pressed?> broadcast (shoot v) and wait wait (0.1) secs // does not wait for the trigger to be released; change to amount of seconds between each shot end when I receive [shoot v] //in projectile sprite go to (The player v) show repeat until <<touching (intended target/s v)?> or <touching (edge v)?>> move (10) steps end hide
Two sprites, one cloning the other
This method is similar to the one above, only it incorporates cloning to allow for more than one bullet on the screen at once. Once again, both a player sprite and a projectile sprite are needed.
Semi-Automatic
when gf clicked // in player sprite forever wait until <key (space v) pressed?> create clone of (bullet v) // clones the projectile sprite wait until <not <key (space v) pressed?>> end when I start as a clone // in projectile sprite repeat until <<touching (intended target/s v)?> or <touching (edge v)?>> move (10) steps end delete this clone
Automatic
when gf clicked // in player sprite forever wait until <key (space v) pressed?> create clone of (bullet v) wait (0.1) secs // change to amount of seconds between each shot end when I start as a clone // in projectile sprite repeat until <<touching (intended target/s v)?> or <touching (edge v)?>> move (10) steps end delete this clone
One sprite cloning itself
This method is more efficient because it only requires one sprite with two costumes: the player and the projectile.
Semi-Automatic
when gf clicked switch costume to (player v) forever wait until <key (space v) pressed?> create clone of (myself v) wait until <not <key (space v) pressed?>> end when I start as a clone switch costume to (bullet v) // makes the clone look like a projectile repeat until <<touching (intended target/s v)?> or <touching (edge v)?> move (10) steps end delete this clone
Automatic
when gf clicked switch costume to (player v) // makes sure the parent sprite looks like the player forever wait until <key (space v) pressed?> create clone of (myself v) wait (0.1) secs // change to amount of seconds between each shot end when I start as a clone switch costume to (bullet v) // makes the clone look like a projectile repeat until <<touching (intended target/s v)?> or <touching (edge v)?> move (10) steps end delete this clone
Tips
- To make the projectile aim at the mouse pointer, place the following block after the "go to x: () y: ()" block:
point towards (mouse-pointer v)
- If the length of the sprite is less than 10 pixels, replace both 10's with at most the length of the sprite, or the sprite may pass through its intended targets.
- One can also change the length of the sprite's costume so that it will still detect the intended targets.
Shooting Projectiles with Trajectories
In Scratch, the Trajectory formula is used for projects such as:
- Rocket or baseball simulators
- Tank games
- Anything that includes the curve of a projectile
The formula(e) calculate(s) where on the screen the projectile should be. As well as calculating this, there are many other formulae that calculate different things
These are the formulae:
Horizontal velocity: v°x = v°cos(ß) Horizontal distance: x = a+v°xt Vertical velocity: v°y = v°sin(ß)-gt Vertical distance: y = b+v°sin(ß)-0.5gt²
v° is the initial velocity, ß is the projectile angle (from -90 to 90), a & b are the starting coordinates, g is the informal gravity constant 9.81, and t is the time since the launch.
Other Formulae
Maximum height: H = b+[v°²sin²(ß)]/[2g] Horizontal range: R = [v°²sin2(ß)]/[g]-a
sin(ß) and cos(ß) are the vertical and horizontal components (or velocities).