- }
- particlex = path[0].x;
- particley = path[0].y;
- particlexv = lhrandom(0, 0.02);
- particlexv = lhrandom(-0.02, 0.02);
- memset(image, 0, BEAMWIDTH * BEAMHEIGHT * sizeof(int));
- for (i = 0;i < 65536;i++)
- {
- for (nearestpathindex = 0;nearestpathindex < PATHPOINTS;nearestpathindex++)
- if (path[nearestpathindex].x > particlex)
- break;
- nearestpathindex %= PATHPOINTS;
- dx = path[nearestpathindex].x + lhrandom(-0.01, 0.01);dx = bound(0, dx, 1) - particlex;if (dx < 0) dx += 1;
- dy = path[nearestpathindex].y + lhrandom(-0.01, 0.01);dy = bound(0, dy, 1) - particley;
- s = path[nearestpathindex].strength / sqrt(dx*dx+dy*dy);
- particlexv = particlexv /* (1 - lhrandom(0.08, 0.12))*/ + dx * s;
- particleyv = particleyv /* (1 - lhrandom(0.08, 0.12))*/ + dy * s;
- particlex += particlexv * maxpathstrength;particlex -= (int) particlex;
- particley += particleyv * maxpathstrength;particley = bound(0, particley, 1);
- px = particlex * BEAMWIDTH;
- py = particley * BEAMHEIGHT;
- if (px >= 0 && py >= 0 && px < BEAMWIDTH && py < BEAMHEIGHT)
- image[py*BEAMWIDTH+px] += 16;
- }
-
- for (py = 0;py < BEAMHEIGHT;py++)
- {
- for (px = 0;px < BEAMWIDTH;px++)
+ particlex = path[0].x;
+ particley = path[0].y;
+ particlexv = lhrandom(0, 0.02);
+ particlexv = lhrandom(-0.02, 0.02);
+ memset(image, 0, BEAMWIDTH * BEAMHEIGHT * sizeof(int));
+ for (i = 0;i < 65536;i++)