// Last edited on 2019-07-17 12:11:37 by stolfilocal // Processed by remove-cam-lights background{ color rgb < 0.5, 0.5, 0.85 > } #declare tx_plastico = texture{ pigment{ color rgb < 0.10, 0.80, 1.00 > } finish{ diffuse 0.8 ambient 0.1 specular 0.5 roughness 0.005 } } #declare tx_fosca = texture{ pigment{ color rgb < 1.00, 0.80, 0.10 > } finish{ diffuse 0.9 ambient 0.1 } } #declare tx_espelho = texture{ pigment{ color rgb < 1.00, 0.85, 0.30 > } finish{ diffuse 0.2 reflection 0.7*< 1.00, 0.85, 0.30 > ambient 0.1 } } #declare tx_vidro = texture{ pigment{ color rgb < 0.85, 0.95, 1.00 > filter 0.70 } finish{ diffuse 0.03 reflection 0.25 ambient 0.02 specular 0.25 roughness 0.005 } } #declare NA = 5; // Num angulos por perna. #declare NQ = 6; // Num quadros. #declare NP = 6; // Num pernas. #declare tx_xadrez = texture{ pigment{ checker color rgb < 0,0,0 >, color rgb < 1,1,1 > } finish{ diffuse 0.9 ambient 0.1 } scale 2.0 } #declare plength = array[NA]; #declare plength[0] = 1; #declare plength[1] = 3; #declare plength[2] = 3; #declare plength[3] = 3; #declare plength[4] = 3; #declare raiop = 0.2; #declare corpo = cylinder { <0, -4, 0>, <0, 4, 0>, 2 } #declare cabeca = union { sphere { <0, 0, 0>, 1 } cone { <0, 0, 0>, 0.2, <0, 6, 0>, 0 } } #macro perna1seg(a1) cylinder { <0, 0, 0>, , raiop rotate <0, a1, 0> } #end #macro perna2seg(a1, a2) union { object {perna1seg(a1) translate } cylinder{ <0, 0, 0>, , raiop } rotate <0, a2, 0> } #end #macro perna3seg(a1, a2, a3) union { object {perna2seg(a1, a2) translate } cylinder{ <0, 0, 0>, , raiop } rotate <0, a3, 0> } #end #macro perna4seg(a1, a2, a3, a4) union { object {perna3seg(a1, a2, a3) translate } cylinder{ <0, 0, 0>, , raiop } rotate <0, a4, 0> } #end #macro perna5seg(a1, a2, a3, a4, a5) union { object {perna4seg(a1, a2, a3, a4) translate } cylinder{ <0, 0, 0>, , raiop } rotate <0, a5, 0> } #end #macro perna(a1, a2, a3, a4, a5) object { perna5seg(a5, a4, a3, a2, a1) translate <2, 0, 0> } #end #macro dragao(A) union { object {corpo} object {cabeca translate <0, 5, 1>} object {perna(A[0][0], A[0][1], A[0][2], A[0][3], A[0][4]) translate <0, 0, 0>} object {perna(A[1][0], A[1][1], A[1][2], A[1][3], A[1][4]) translate <0, 2, 0>} object {perna(A[2][0], A[2][1], A[2][2], A[2][3], A[2][4]) translate <0, -2, 0>} object {perna(A[3][0], A[3][1], A[3][2], A[3][3], A[3][4]) translate <0, 0, 0> scale <-1, 1, 1>} object {perna(A[4][0], A[4][1], A[4][2], A[4][3], A[4][4]) translate <0, 2, 0> scale <-1, 1, 1>} object {perna(A[0][0], A[0][1], A[0][2], A[0][3], A[0][4]) translate <0, -2, 0> scale <-1, 1, 1>} texture { tx_fosca } rotate <10, 0, -50> } #end #macro interpolin(t0, v0, t1, v1, tt) #local r = (tt-t0)/(t1-t0); #local s = 1-r; #local vv = s*v0 + r*v1; vv #end #declare roleta = seed(4615); #declare Q = array[NQ]; #declare i = 0; #while (i < NQ) #declare Q[i] = array[NP]; #declare j = 0; #while (j < NP) #declare Q[i][j] = array[NA]; #declare j = j + 1; #end #declare i = i + 1; #end #declare i = 0; #while (i < NP) #declare Q[0][i][0] = - 30 - 30*rand(roleta); #declare Q[0][i][1] = 90; #declare Q[0][i][2] = 90; #declare Q[0][i][3] = -90; #declare Q[0][i][4] = -45; #declare i = i + 1; #end #declare i = 0; #while (i < NP) #declare Q[1][i][0] = -20; #declare Q[1][i][1] = 67; #declare Q[1][i][2] = 30 + 40*rand(roleta); #declare Q[1][i][3] = -73; #declare Q[1][i][4] = -35; #declare i = i + 1; #end #declare i = 0; #while (i < NP) #declare Q[2][i][0] = 20; #declare Q[2][i][1] = 44; #declare Q[2][i][2] = 44; #declare Q[2][i][3] = -30 - 30*rand(roleta); #declare Q[2][i][4] = -25; #declare i = i + 1; #end #declare i = 0; #while (i < NP) #declare Q[3][i][0] = 60; #declare Q[3][i][1] = 21 + 30*rand(roleta); #declare Q[3][i][2] = 21; #declare Q[3][i][3] = -41; #declare Q[3][i][4] = - 15 - 20*rand(roleta); #declare i = i + 1; #end #declare i = 0; #while (i < NP) #declare Q[4][i][0] = 20; #declare Q[4][i][1] = 44; #declare Q[4][i][2] = 14 + 40*rand(roleta); #declare Q[4][i][3] = -58; #declare Q[4][i][4] = -25; #declare i = i + 1; #end #declare i = 0; #while (i < NP) #declare Q[5][i][0] = - 20 - 20*rand(roleta); #declare Q[5][i][1] = 67; #declare Q[5][i][2] = 67; #declare Q[5][i][3] = -73; #declare Q[5][i][4] = -35; #declare i = i + 1; #end #declare tk = array[NQ+1]; #declare tk[0] = (1/NQ) * 0; #declare tk[1] = (1/NQ) * 1; #declare tk[2] = (1/NQ) * 2; #declare tk[3] = (1/NQ) * 3; #declare tk[4] = (1/NQ) * 4; #declare tk[5] = (1/NQ) * 5; #declare tk[6] = 1.0; #declare A = array[NP]; #declare A[0] = array[NA]; #declare A[1] = array[NA]; #declare A[2] = array[NA]; #declare A[3] = array[NA]; #declare A[4] = array[NA]; #declare A[5] = array[NA]; #macro interpola_quadros(NP, NA, Qu, k0, t0, k1, t1, tt, Au) #declare quadro_inicial = Qu[k0]; #declare quadro_final = Qu[k1]; #declare i = 0; #while (i < NP) #declare j = 0; #while (j < NA) #declare a0 = quadro_inicial[i][j]; #declare a1 = quadro_final[i][j]; #declare Au[i][j] = interpolin(t0, a0, t1, a1, tt); #declare j = j + 1; #end #declare i = i + 1; #end #end #macro busca_clock(clk, NQ, tk) #local i = 1; #local ret = NQ-1; #while (i <= NQ) #if (clk <= tk[i]) #local ret = i-1; #local i = NQ+1; #end #local i = i + 1; #end ret #end #macro quadro(clk) #declare qu = busca_clock(clk, NQ, tk); #declare qa = qu+1; #if(qa >= NQ) interpola_quadros(NP, NA, Q, qu, tk[qu], 0, 1, clk, A) #else interpola_quadros(NP, NA, Q, qu, tk[qu], qa, tk[qa], clk, A) #end object{ dragao(A) scale <0.5, 0.5, 0.5> } #end quadro(clock) #include "eixos.inc" // object{ eixos(10) } #include "camlight.inc" #declare centro_cena = < 0.00, 0.00, -3.00 >; #declare raio_cena = 10.0; #declare dir_camera = < 7.00, 20.00, 7.00 >; #declare dist_camera = 5*raio_cena; #declare intens_luz = 1.20; camlight(centro_cena, raio_cena, dir_camera, dist_camera , z, intens_luz)