summaryrefslogtreecommitdiff
path: root/Examples/GIFPlot/Perl5/shadow
diff options
context:
space:
mode:
Diffstat (limited to 'Examples/GIFPlot/Perl5/shadow')
-rw-r--r--Examples/GIFPlot/Perl5/shadow/Makefile25
-rw-r--r--Examples/GIFPlot/Perl5/shadow/README2
-rw-r--r--Examples/GIFPlot/Perl5/shadow/cmapbin0 -> 768 bytes
-rw-r--r--Examples/GIFPlot/Perl5/shadow/runme.pl68
4 files changed, 95 insertions, 0 deletions
diff --git a/Examples/GIFPlot/Perl5/shadow/Makefile b/Examples/GIFPlot/Perl5/shadow/Makefile
new file mode 100644
index 0000000..c39eac5
--- /dev/null
+++ b/Examples/GIFPlot/Perl5/shadow/Makefile
@@ -0,0 +1,25 @@
+TOP = ../../..
+SWIG = $(TOP)/../swig
+SWIGOPT = -outcurrentdir
+SRCS =
+TARGET = gifplot
+INTERFACEDIR = ../../Interface/
+INTERFACE = gifplot.i
+LIBS = -L../.. -lgifplot -lm
+INCLUDES = -I../../Include
+
+all::
+ $(MAKE) -f $(TOP)/Makefile SRCS='$(SRCS)' SWIG='$(SWIG)' \
+ INCLUDES='$(INCLUDES)' LIBS='$(LIBS)' SWIGOPT='$(SWIGOPT)' \
+ TARGET='$(TARGET)' INTERFACE='$(INTERFACE)' INTERFACEDIR='$(INTERFACEDIR)' perl5
+
+static::
+ $(MAKE) -f $(TOP)/Makefile SRCS='$(SRCS)' SWIG='$(SWIG)' \
+ INCLUDES='$(INCLUDES)' LIBS='$(LIBS)' SWIGOPT='$(SWIGOPT)' \
+ TARGET='myperl' INTERFACE='$(INTERFACE)' INTERFACEDIR='$(INTERFACEDIR)' perl5_static
+
+clean::
+ $(MAKE) -f $(TOP)/Makefile perl5_clean
+ rm -f *.gif
+
+check: all
diff --git a/Examples/GIFPlot/Perl5/shadow/README b/Examples/GIFPlot/Perl5/shadow/README
new file mode 100644
index 0000000..ab12e34
--- /dev/null
+++ b/Examples/GIFPlot/Perl5/shadow/README
@@ -0,0 +1,2 @@
+This example use the file in ../../Interface/gifplot.i to build
+an interface with shadow classes. Run the script 'runme.pl'.
diff --git a/Examples/GIFPlot/Perl5/shadow/cmap b/Examples/GIFPlot/Perl5/shadow/cmap
new file mode 100644
index 0000000..a20c331
--- /dev/null
+++ b/Examples/GIFPlot/Perl5/shadow/cmap
Binary files differ
diff --git a/Examples/GIFPlot/Perl5/shadow/runme.pl b/Examples/GIFPlot/Perl5/shadow/runme.pl
new file mode 100644
index 0000000..c396251
--- /dev/null
+++ b/Examples/GIFPlot/Perl5/shadow/runme.pl
@@ -0,0 +1,68 @@
+# Plot a 3D function
+use gifplot;
+package gifplot;
+
+# Here is the function to plot
+sub func {
+ my $x = shift;
+ my $y = shift;
+ return 5*cos(2*sqrt($x*$x+$y*$y))*exp(-0.3*sqrt($x*$x+$y*$y));
+}
+
+# Here are some plotting parameters
+$xmin = -5.0;
+$xmax = 5.0;
+$ymin = -5.0;
+$ymax = 5.0;
+$zmin = -5.0;
+$zmax = 5.0;
+
+# Grid resolution
+$nxpoints = 60;
+$nypoints = 60;
+
+$cmap = new gifplot::ColorMap("cmap");
+$frame = new gifplot::FrameBuffer(500,500);
+$frame->clear($BLACK);
+
+$p3 = new gifplot::Plot3D($frame,$xmin,$ymin,$zmin,$xmax,$ymax,$zmax);
+$p3->lookat(2*($zmax-$zmin));
+$p3->autoperspective(40);
+$p3->rotu(60);
+$p3->rotr(30);
+$p3->rotd(10);
+
+sub drawsolid {
+ $p3->clear($BLACK);
+ $p3->start();
+ my $dx = 1.0*($xmax-$xmin)/$nxpoints;
+ my $dy = 1.0*($ymax-$ymin)/$nypoints;
+ my $cscale = 240.0/($zmax-$zmin);
+ my $x = $xmin;
+ for ($i = 0; $i < $nxpoints; $i++) {
+ my $y = $ymin;
+ for ($j = 0; $j < $nypoints; $j++) {
+ my $z1 = func($x,$y);
+ my $z2 = func($x+$dx,$y);
+ my $z3 = func($x+$dx,$y+$dy);
+ my $z4 = func($x,$y+$dy);
+ my $c1 = $cscale*($z1-$zmin);
+ my $c2 = $cscale*($z2-$zmin);
+ my $c3 = $cscale*($z3-$zmin);
+ my $c4 = $cscale*($z4-$zmin);
+ my $c = ($c1+$c2+$c3+$c4)/4;
+ if ($c < 0) { $c = 0; }
+ if ($c > 239) { $c = 239; }
+ $p3->solidquad($x,$y,$z1,$x+$dx,$y,$z2,$x+$dx,$y+$dy,$z3,$x,$y+$dy,$z4,$c+16);
+ $y = $y + $dy;
+ }
+ $x = $x + $dx;
+ }
+}
+
+print "Making a nice 3D plot...\n";
+drawsolid();
+
+$frame->writeGIF($cmap,"image.gif");
+print "Wrote image.gif\n";
+