Mercurial > hg > Game > Cerium
view old/tmp/revers.pl @ 996:bac3b0afc3e8 draft
add sdl_test file
author | yutaka@charles.cr.ie.u-ryukyu.ac.jp |
---|---|
date | Mon, 11 Oct 2010 18:56:51 +0900 |
parents | fb88a682109e |
children |
line wrap: on
line source
#!/usr/bin/perl # fix Cerium xml normal vector my $i = -1; my (@x,@y,@z); my @cord; my $flag = 0; my $fix = 1; sub v { print "$x[0] $y[0] $z[0]\n"; print "$x[1] $y[1] $z[1]\n"; print "$x[2] $y[2] $z[2]\n"; } sub outer { my ($ax,$ay,$az) = ( $x[1]-$x[0], $y[1]-$y[0], $z[1]-$z[0], ); my ($bx,$by,$bz) = ( $x[2]-$x[0], $y[2]-$y[0], $z[2]-$z[0], ); my ($ox,$oy,$oz) = ( $ay*$bz - $az*$by, -$ax*$bz + $az*$bx, $ax*$by - $ay*$bx, ); my($r) = sqrt($ox*$ox+$oy*$oy+$oz*$oz); ($ox,$oy,$oz) = ($ox/$r,$oy/$r,$oz/$r); push(@cord, [$ox,$oy,$oz]); # print " $ox $oy $oz\n"; } if (@ARGV != 2) { die "Usage : objectname filename\n"; } my ($object, $file) = @ARGV; open(IN, $file); while(<IN>) { if (! $fix) { if (/<sur/) { print; next; } } if (/<normal/) { $i= -2; print if ($fix); next; } if (/<\/normal/) { $i = -1; print if ($fix); next; } if (/$object/) { $flag = 1; } if (/\/$object/) { $flag = 0; } if ( $i < -1) { if ($i== -4) { my $cord = shift(@cord); if ($fix) { if ($flag == 1) { $cord->[0] = -$cord->[0]; $cord->[1] = -$cord->[1]; $cord->[2] = -$cord->[2]; } print " $cord->[0] $cord->[1] $cord->[2] \n"; print " $cord->[0] $cord->[1] $cord->[2] \n"; print " $cord->[0] $cord->[1] $cord->[2] \n"; } else { print "outer $i $cord->[0] $cord->[1] $cord->[2] \n"; print ; } $i = -2; } else { $i--; } next; } print if ($fix); if (/<\/coord/) { $i = -1; next; } if (/<coord/) { @cord = (); $i=0; next; } if ($i<0) { next; } if (/([-]*[.\d]+)\s+([-]*[.\d]+)\s+([-]*[.\d]+)/) { ($x[$i],$y[$i],$z[$i]) = ($1,$2,$3); # print "$i $_"; if ($i==2) { &outer; $i = 0; next; } $i++; } else { $i = -1; } } # end