| author | Axel Jacobs <axel@jaloxa.eu> |
| Thu, 30 Jan 2014 21:54:21 +0000 | |
| changeset 55 | e00e7d28865e |
| parent 54 | be2807ee7183 |
| child 56 | 259ce6d95331 |
| permissions | -rwxr-xr-x |
| 54 | 1 |
#!/usr/bin/perl |
2 |
||
3 |
# Make a nice multi-view picture of a luminaire |
|
4 |
# |
|
5 |
# This is based on objpict.pl that renders four-view |
|
6 |
# images of objects that are not light sources. |
|
7 |
# |
|
8 |
# Written by Axel Jacobs, |
|
9 |
# with input from Rob Guglielmetti and Gre |
|
10 |
||
11 |
use strict; |
|
12 |
use warnings; |
|
13 |
||
14 |
use File::Temp qw/ tempdir /; |
|
15 |
#my $td = tempdir( CLEANUP => 1 ); |
|
16 |
my $td = "tmp"; |
|
17 |
||
18 |
#my $xres = 1024; |
|
19 |
#my $yres = 1024; |
|
20 |
my $xres = 600; |
|
21 |
my $yres = 600; |
|
22 |
my $tiny = 0.01; |
|
|
55
e00e7d28865e
ltpict: Change default scale factor.
Axel Jacobs <axel@jaloxa.eu>
parents:
54
diff
changeset
|
23 |
my $is_ies = 0; |
| 54 | 24 |
my $rpict_cmd = "rpict -ab 0 -ds 0 -dv -av 0 0 0 -x $xres -y $yres"; |
25 |
my $pfilt_cmd = "pfilt -r .6 -x /2 -y /2"; |
|
26 |
||
|
55
e00e7d28865e
ltpict: Change default scale factor.
Axel Jacobs <axel@jaloxa.eu>
parents:
54
diff
changeset
|
27 |
my $ies = "$td/dist.ies"; |
|
e00e7d28865e
ltpict: Change default scale factor.
Axel Jacobs <axel@jaloxa.eu>
parents:
54
diff
changeset
|
28 |
my $fittings = "$td/fitting.rad"; |
| 54 | 29 |
my $material = "$td/lt.mat"; |
30 |
my $testroom1 = "$td/testroom1.rad"; |
|
31 |
my $testroom2 = "$td/testroom2.rad"; |
|
32 |
my $testroom3 = "$td/testroom3.rad"; |
|
33 |
my $testroom4 = "$td/testroom4.rad"; |
|
34 |
my $octree1 = "$td/lt1.oct"; |
|
35 |
my $octree2 = "$td/lt2.oct"; |
|
36 |
my $octree3 = "$td/lt3.oct"; |
|
37 |
my $octree4 = "$td/lt4.oct"; |
|
38 |
||
|
55
e00e7d28865e
ltpict: Change default scale factor.
Axel Jacobs <axel@jaloxa.eu>
parents:
54
diff
changeset
|
39 |
# Parse command line arguments |
|
e00e7d28865e
ltpict: Change default scale factor.
Axel Jacobs <axel@jaloxa.eu>
parents:
54
diff
changeset
|
40 |
if ("$ARGV[0]" eq '-i') { # File is an IES file, not Radiance luminaire
|
|
e00e7d28865e
ltpict: Change default scale factor.
Axel Jacobs <axel@jaloxa.eu>
parents:
54
diff
changeset
|
41 |
$is_ies = 1; |
|
e00e7d28865e
ltpict: Change default scale factor.
Axel Jacobs <axel@jaloxa.eu>
parents:
54
diff
changeset
|
42 |
shift @ARGV; |
|
e00e7d28865e
ltpict: Change default scale factor.
Axel Jacobs <axel@jaloxa.eu>
parents:
54
diff
changeset
|
43 |
} |
| 54 | 44 |
# We need at least one Radiance file or a scene on STDIN (but not both) |
45 |
if ($#ARGV < 0) {
|
|
46 |
open(FH, ">$td/stdin.rad") or |
|
47 |
die("objview: Can't write to temporary file $td/stdin.rad\n");
|
|
48 |
while (<>) {
|
|
49 |
print FH; |
|
50 |
} |
|
51 |
# Pretend stdin.rad was passed as argument. |
|
52 |
@ARGV = ("$td/stdin.rad");
|
|
53 |
} |
|
54 |
||
55 |
||
56 |
# Scale fitting and center at origin |
|
57 |
my $dimstr = `getbbox -h @ARGV`; |
|
58 |
chomp $dimstr; |
|
59 |
# Values returned by getbbox are indented and delimited with multiple spaces. |
|
60 |
$dimstr =~ s/^\s+//; # remove leading spaces |
|
61 |
my @dims = split(/\s+/, $dimstr); # convert to array |
|
62 |
||
63 |
# Find largest axes-aligned dimension |
|
64 |
my @diffs = ($dims[1]-$dims[0], $dims[3]-$dims[2], $dims[5]-$dims[4]); |
|
65 |
@diffs = reverse sort { $a <=> $b } @diffs;
|
|
66 |
my $size = $diffs[0]; |
|
67 |
||
68 |
# Move fitting so centre is at origin |
|
69 |
my $xtrans = -1.0 * ($dims[0] + $dims[1]) / 2; |
|
70 |
my $ytrans = -1.0 * ($dims[2] + $dims[3]) / 2; |
|
71 |
my $ztrans = -1.0 * ($dims[4] + $dims[5]) / 2; |
|
72 |
# Scale so that largest object dimension is unity |
|
|
55
e00e7d28865e
ltpict: Change default scale factor.
Axel Jacobs <axel@jaloxa.eu>
parents:
54
diff
changeset
|
73 |
my $scale = 0.001 / $size; |
| 54 | 74 |
|
75 |
my $fitting = "$td/fitting.rad"; |
|
76 |
open(FH, ">$fitting") or |
|
77 |
die("Can\'t write to temporary file $fitting");
|
|
78 |
print FH "!xform -t $xtrans $ytrans $ztrans -s $scale @ARGV"; |
|
79 |
close FH; |
|
80 |
||
81 |
||
82 |
# Material for the room |
|
83 |
open(FH, ">$material") or |
|
84 |
die("Can\'t write to temporary file $material");
|
|
85 |
print FH "void plastic wall_mat 0 0 5 .5 .5 .5 0 0"; |
|
86 |
close FH; |
|
87 |
||
88 |
||
89 |
# Different 'room' geometry for different views |
|
90 |
my $OFFSET = 0.1; |
|
91 |
open(FH, ">$testroom1") or die("Can\'t write to temporary file $testroom1");
|
|
92 |
# C0-C180 |
|
93 |
print FH "wall_mat polygon box.4620 0 0 12 -$OFFSET -5 5 -$OFFSET 5 5 -$OFFSET 5 -5 -$OFFSET -5 -5"; |
|
94 |
close(FH); |
|
95 |
||
96 |
open(FH, ">$testroom2") or die("Can\'t write to temporary file $testroom2");
|
|
97 |
# C90-C270 |
|
98 |
print FH "wall_mat polygon box.1540 0 0 12 5 $OFFSET -5 5 $OFFSET 5 -5 $OFFSET 5 -5 $OFFSET -5"; |
|
99 |
close(FH); |
|
100 |
||
101 |
open(FH, ">$testroom3") or die("Can\'t write to temporary file $testroom3");
|
|
102 |
# Lower hemisphere |
|
103 |
print FH "wall_mat bubble lower 0 0 4 0 0 $dims[4] 5"; |
|
104 |
close(FH); |
|
105 |
||
106 |
open(FH, ">$testroom4") or die("Can\'t write to temporary file $testroom4");
|
|
107 |
# Upper hemisphere |
|
108 |
print FH "wall_mat bubble upper 0 0 4 0 0 $dims[5] 5"; |
|
109 |
close(FH); |
|
110 |
||
111 |
||
112 |
# Get bbox again, for the translated and scaled fitting. |
|
113 |
$dimstr = `getbbox -h $fitting`; |
|
114 |
chomp $dimstr; |
|
115 |
# Values returned by getbbox are indented and delimited with multiple spaces. |
|
116 |
$dimstr =~ s/^\s+//; # remove leading spaces |
|
117 |
@dims = split(/\s+/, $dimstr); # convert to array |
|
118 |
||
119 |
# Define the four views |
|
120 |
my $vw1 = "-vtl -vp 4.5 0 0 -vd -1 0 0 -vh 10 -vv 10"; |
|
121 |
my $vw2 = "-vtl -vp 0 -4.5 0 -vd 0 1 0 -vh 10 -vv 10"; |
|
122 |
my $zcent3 = $dims[4] - $tiny; |
|
123 |
my $vw3 = "-vta -vp 0 0 $zcent3 -vd 0 0 -1 -vu 0 1 0 -vh 180 -vv 180"; |
|
124 |
my $zcent4 = $dims[5] + $tiny; |
|
125 |
my $vw4 = "-vta -vp 0 0 $zcent4 -vd 0 0 1 -vu 0 1 0 -vh 180 -vv 180"; |
|
126 |
||
127 |
system "oconv $material $testroom1 $fitting > $octree1"; |
|
128 |
system "oconv $material $testroom2 $fitting > $octree2"; |
|
129 |
system "oconv $material $testroom3 $fitting > $octree3"; |
|
130 |
system "oconv $material $testroom4 $fitting > $octree4"; |
|
131 |
||
132 |
# Render four different views of the objects |
|
133 |
system "$rpict_cmd $vw1 $octree1 > $td/right.hdr"; |
|
134 |
system "$rpict_cmd $vw2 $octree2 > $td/front.hdr"; |
|
135 |
system "$rpict_cmd $vw3 $octree3 > $td/down.hdr"; |
|
136 |
system "$rpict_cmd $vw4 $octree4 > $td/up.hdr"; |
|
137 |
||
138 |
# Compose the four views into one image |
|
139 |
my $cmd; |
|
140 |
my $vtl = "$td/vtl.hdr"; |
|
141 |
my $vta = "$td/vta.hdr"; |
|
142 |
||
143 |
# Auto-expose right/front and down/up pairs separately |
|
144 |
system "pcompos $td/right.hdr 0 0 $td/front.hdr $xres 0 |$pfilt_cmd > $vtl"; |
|
145 |
system "pcompos $td/down.hdr 0 0 $td/up.hdr $xres 0 |$pfilt_cmd > $vta"; |
|
146 |
my $yres2 = $yres / 2; |
|
147 |
exec "pcompos $vtl 0 0 $vta 0 $yres2"; |
|
148 |
||
149 |
#EOF |