File: ball.pl

package info (click to toggle)
swig 1.1p5-1
  • links: PTS
  • area: main
  • in suites: hamm
  • size: 9,448 kB
  • ctags: 5,025
  • sloc: cpp: 21,599; ansic: 13,333; yacc: 3,297; python: 2,794; makefile: 2,197; perl: 1,984; tcl: 1,583; sh: 736; lisp: 201; objc: 143
file content (52 lines) | stat: -rw-r--r-- 1,391 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
# Plot a 3D function
use gifplot;
package gifplot;

# Make a big ball

sub ball {
    my ($p3,$dtheta,$dphi,$r) = @_;
    my $drtheta = $dtheta*3.14159/180.0;
    my $drphi = $dphi*3.14159/180.0;
    my $theta = 0;
    while ($theta < 360) {
	my $phi = -90.0;
	my $rtheta = $theta*3.14159/180.0;
	while ($phi < 90) {
	    my $rphi = $phi*3.14159/180.0;
	    my $x1 = $r*cos($rtheta)*cos($rphi);
	    my $y1 = $r*sin($rtheta)*cos($rphi);
	    my $x2 = $r*cos($rtheta+$drtheta)*cos($rphi);
	    my $y2 = $r*sin($rtheta+$drtheta)*cos($rphi);
	    my $x3 = $r*cos($rtheta+$drtheta)*cos($rphi+$drphi);
	    my $y3 = $r*sin($rtheta+$drtheta)*cos($rphi+$drphi);
	    my $x4 = $r*cos($rtheta)*cos($rphi+$drphi);
	    my $y4 = $r*sin($rtheta)*cos($rphi+$drphi);
	    my $z1 = $r*sin($rphi);
	    my $z2 = $r*sin($rphi+$drphi);
	    my $c = int ((($z1+$r)/(2*$r))*128 + 64);
	    $p3->solidquad($x1,$y1,$z1,$x2,$y2,$z1,$x3,$y3,$z2,$x4,$y4,$z2,$c);
	    $p3->quad($x1,$y1,$z1,$x2,$y2,$z1,$x3,$y3,$z2,$x4,$y4,$z2,$BLACK);
	    $phi = $phi+$dphi;
	}
	$theta = $theta + $dtheta;
    }
}

$f = new FrameBuffer(500,500);
$cm = new ColorMap("cmap");
$p3 = new Plot3D($f,-10,-10,-10,10,10,10);
$p3->lookat(40);
$p3->autoperspective(40);
$p3->clear($BLACK);
$p3->rotu(60);
$p3->rotr(30);
$p3->rotd(10);
$p3->start();
ball($p3,10,10,10);

$f->writeGIF($cm,"ball.gif");

print "Image written to 'ball.gif'\n";