Hm.   I re-read your initial request, and thought about how the particles spat out from the clown running around the track in my demo.   You know, the one where you pressed one of the buttons and left a flurry of red particles in his wake.  If you're bogged down by too many particles appearing at a given time, it's based on your event code and how you use the script calls within.
The number of particles appearing from the event is solely based upon how many frames you wait and how many calls are made.  And the particle spread behind the clown (defined in event ID 10)  is generated thus:
Code:
@script: particle_fx(9,'sparks','screen')
@script: particle_fx(9,'sparks','screen')
@script: particle_fx(9,'sparks','screen')
@script: particle_fx(9,'sparks','screen')
In doing so, I make four trailing particles every frame that the user presses the 'X' button (aka the 'A' keyboard key).  To slow down generation, one can add 
@wait_count = 3 to slow this down to run only after 3 frames of animation speed, and remove one or more particle effect calls to reduce the number generated at any given time.
Code:
@script: @wait_count = 3
@script: particle_fx(9,'sparks','screen')
@script: particle_fx(9,'sparks','screen')
How fast they move from their point of origin, aka its velocity, is solely within the P_Defined array... particularly the 'horizontal' and 'vertical' arrays within.  Each one of those arrays holds 3 values which manipulates its speed and gives a little random variance value.  Hey, you don't want all the particles to move EXACTLY the same, right?
The first two values in the Horiz & Vert arrays handle direction in pixels. In the case of the sparks in my demo, this is set to -5, 10.  This means it can go 5 px in one direction with a randomization of 1-10 pixels in another direction (ie... -4px to 5px) whether this is the horizontal or vertical array.  Granted, that is TOO fast with the system's 40FPS frame rate, so the array has a 3rd value to slow the particle speed down... the multiplier.  Again, using the sparks particle in my demo, I have this set to 0.5, but you could set that to 0.3 to make them travel slower from their point of generation or even 0.1.  You could even make the particles remain stationary and not move at all.  But to do so, do not enter a value of 0.  The value must be 0.0 for a stationary particle as the value itself MUST be a floating point value.
* The 
Velocity value and formula I mentioned is covered in the demo's PDF file
The speed in which the particles fade away is based on the 'Opacity' array within P_Defined, and also has a little 'variance' option within.  And after that, you have a 'Spin' array which indicates how fast the particles spin and in which direction.  Granted, a spin of 0 means it isn't spinning at all.
Sorry for the late summary, but I've been busy working.  With that, you shouldn't have need for my previous code insert from a couple days ago. 
