| 1 | greg | 1.1 | #!/bin/csh -f | 
| 2 | greg | 2.6 | # RCSid: $Id: objpict.csh,v 2.5 2008/11/10 19:08:19 greg Exp $ | 
| 3 | greg | 1.1 | # | 
| 4 |  |  | # Make a nice multi-view picture of an object | 
| 5 | greg | 2.3 | # Command line arguments contain materials and object files | 
| 6 | greg | 1.1 | # | 
| 7 | greg | 2.6 | set tmpdir=/tmp/objv$$ | 
| 8 | greg | 1.1 | set xres=250 | 
| 9 |  |  | set yres=250 | 
| 10 | greg | 2.3 | set rpict="rpict -av .2 .2 .2 -x $xres -y $yres" | 
| 11 | greg | 2.6 | set inprad=$tmpdir/op.rad | 
| 12 |  |  | set testroom=$tmpdir/testroom.rad | 
| 13 |  |  | set octree=$tmpdir/op.oct | 
| 14 |  |  | set pict1=$tmpdir/opa.hdr | 
| 15 |  |  | set pict2=$tmpdir/opb.hdr | 
| 16 |  |  | set pict3=$tmpdir/opc.hdr | 
| 17 |  |  | set pict4=$tmpdir/opd.hdr | 
| 18 | greg | 1.1 | onintr quit | 
| 19 | greg | 2.3 | if ( $#argv ) then | 
| 20 |  |  | cat $* > $inprad | 
| 21 |  |  | else | 
| 22 |  |  | cat > $inprad | 
| 23 |  |  | endif | 
| 24 | greg | 2.6 | cat > $testroom << '_EOF_' | 
| 25 |  |  | void plastic wall_mat 0 0 5 .681 .543 .686 0 .2 | 
| 26 |  |  | void light bright 0 0 3 3000 3000 3000 | 
| 27 |  |  | bright sphere lamp0 0 0 4 4 4 -4 .1 | 
| 28 |  |  | bright sphere lamp1 0 0 4 4 0 4 .1 | 
| 29 |  |  | bright sphere lamp2 0 0 4 0 4 4 .1 | 
| 30 |  |  | wall_mat polygon box.1540 0 0 12 | 
| 31 |  |  | 5                 -5                 -5 | 
| 32 |  |  | 5                 -5                  5 | 
| 33 |  |  | -5                 -5                  5 | 
| 34 |  |  | -5                 -5                 -5 | 
| 35 |  |  | wall_mat polygon box.4620 0 0 12 | 
| 36 |  |  | -5                 -5                  5 | 
| 37 |  |  | -5                  5                  5 | 
| 38 |  |  | -5                  5                 -5 | 
| 39 |  |  | -5                 -5                 -5 | 
| 40 |  |  | wall_mat polygon box.2310 0 0 12 | 
| 41 |  |  | -5                  5                 -5 | 
| 42 |  |  | 5                  5                 -5 | 
| 43 |  |  | 5                 -5                 -5 | 
| 44 |  |  | -5                 -5                 -5 | 
| 45 |  |  | wall_mat polygon box.3267 0 0 12 | 
| 46 |  |  | 5                  5                 -5 | 
| 47 |  |  | -5                  5                 -5 | 
| 48 |  |  | -5                  5                  5 | 
| 49 |  |  | 5                  5                  5 | 
| 50 |  |  | wall_mat polygon box.5137 0 0 12 | 
| 51 |  |  | 5                 -5                  5 | 
| 52 |  |  | 5                 -5                 -5 | 
| 53 |  |  | 5                  5                 -5 | 
| 54 |  |  | 5                  5                  5 | 
| 55 |  |  | wall_mat polygon box.6457 0 0 12 | 
| 56 |  |  | -5                  5                  5 | 
| 57 |  |  | -5                 -5                  5 | 
| 58 |  |  | 5                 -5                  5 | 
| 59 |  |  | 5                  5                  5 | 
| 60 |  |  | '_EOF_' | 
| 61 | greg | 2.3 | set dims=`getbbox -h $inprad` | 
| 62 |  |  | set siz=`rcalc -n -e 'max(a,b):if(a-b,a,b);$1='"max($dims[2]-$dims[1],max($dims[4]-$dims[3],$dims[6]-$dims[5]))"` | 
| 63 | greg | 1.1 | set vw1="-vtl -vp 2 .5 .5 -vd -1 0 0 -vh 1 -vv 1" | 
| 64 |  |  | set vw2="-vtl -vp .5 2 .5 -vd 0 -1 0 -vh 1 -vv 1" | 
| 65 |  |  | set vw3="-vtl -vp .5 .5 2 -vd 0 0 -1 -vu -1 0 0 -vh 1 -vv 1" | 
| 66 |  |  | set vw4="-vp 3 3 3 -vd -1 -1 -1 -vh 20 -vv 20" | 
| 67 |  |  |  | 
| 68 | greg | 2.3 | xform -t `ev "-($dims[1]+$dims[2])/2" "-($dims[3]+$dims[4])/2" "-($dims[5]+$dims[6])/2"` \ | 
| 69 |  |  | -s `ev 1/$siz` -t .5 .5 .5 $inprad \ | 
| 70 | greg | 2.6 | | oconv $testroom - > $octree | 
| 71 | greg | 1.1 | $rpict $vw1 $octree > $pict1 | 
| 72 |  |  | $rpict $vw2 $octree > $pict2 | 
| 73 |  |  | $rpict $vw3 $octree > $pict3 | 
| 74 |  |  | $rpict $vw4 $octree > $pict4 | 
| 75 |  |  | pcompos $pict3 0 $yres $pict4 $xres $yres $pict1 0 0 $pict2 $xres 0 | 
| 76 |  |  |  | 
| 77 |  |  | quit: | 
| 78 | greg | 2.6 | rm -r $tmpdir | 
| 79 | greg | 1.1 | exit 0 |