- /
-
The MATropolis Five-O
on 3 Dec 2023
- 9
- 219
- 0
- 4
- 1997
drawframe(1);
This is a remix of Shanshan's 2D car.
The hit-and-run suspect was arrested by the MATropolis Five-O and is once again a crime-free city.
Write your drawframe function below
function drawframe(f)
persistent hg v hg2 hg2L hg2g
if f==1 || isempty(hg)
%% plot the city
rng default
set(gcf,color='k')
n=20;
bh=randg(1,n); % building heights
bh(9,2:end)=nan; % make way for a street
v=[16,8];
bh(:,v)=nan; % remove 2 horizontal rows to create streets
colormap gray
camproj per
hold on
axis equal off
b=bar3(bh);
set(b,{'CData'},get(b,'ZData'),{'FaceC'},{'i'})
clim([-1 5])
camva(30)
campos([21.3 8.8 1])
camtarget([8.6 9.6 .6]);
% Add windows
for i=1:n % rows of buildings
for j=1:n % columns of buildings
c=0.1:0.2:bh(i,j)-.2;
d=[c;c];
z=d(:)'+[0;0;.1;.1];
y=i+[-.2,.2]+[-1;1;1;-1]/12;
y=repmat(y,size(c));
ison=logical(rand(1,numel(d))>0.33); % some window lights will be off
rgb=[j,j]./n.*0.5+0.5; % R & G range 0.5 to 1, back to front
rgb(3)=1-rgb(1); % B ranges 0.5 to 0, back to front
patch(z(:,ison)*0+j+.45,y(:,ison),z(:,ison),rgb);
patch(z(:,~ison)*0+j+.45,y(:,~ison),z(:,~ison),[.19 .18 .03]);
end
end
% Add ground
q=2e3;
Ig=imgaussfilt(rand(q),2);
bx=linspace(0,n+1,q);
Igclim=[-1,1];
Igs=(Ig-min(Ig(:)))/range(Ig(:))*range(Igclim)+Igclim(1); % Scaled to clim
surf(bx,bx,zeros(q)+.05,FaceC='tex',CData=Igs,EdgeColor='n');
% Add Shanshan's 2D car, for now it will be oriented on the XY plane
hg=hgtransform(Par=gca);
patch(Faces=1:7,Vertices=[0.4 -3.2;0.4 0.0;1.4 -0.4;1.4 -0.8;2.4 -1.2;2.4 -3.2;0.4 -3.2],FaceC='k',Par=hg) % body
patch(Faces=1:4,Vertices=[1.6 -1.7;1.6 -1.2;2.1 -1.4;2.1 -1.7],FaceC='y',Par=hg) % window
rectangle(Position=[0 -1.5 1 1],Curv=1,FaceC='y',Par=hg) % front wheel
rectangle(Position=[0 -3 1 1],Curv=1,FaceC='y',Par=hg) % back wheel
rectangle(Position=[.25 -1.25 0.5 0.5],Curv=1,FaceC='k',Par=hg) % front inner wheel
rectangle(Position=[.25 -2.75 0.5 0.5],Curv=1,FaceC='k',Par=hg) % back inner wheel
% Create MATropolis public safety patrol car
hg2=copyobj(hg,gca);
hg2.Children(end).FaceColor='#3F57A9';
hg2L=rectangle(Position=[2.4 -2 0.4 0.3],Curv=.3,FaceC='b',Par=hg2); % roof light
% Add light glow
[th,rh]=meshgrid(linspace(0,2*pi,20),linspace(0,2,20));
[gx,gy]=pol2cart(th,rh);
hp = hg2L.Position;
hg2g=surf(gx+hp(1),gy+hp(2),0*gx,FaceC='r',EdgeC='n',FaceA='i',AlphaData=-rh,Par=hg2);
alim([-2,1])
end
% light sequence
r=[1 .5 .5];
b=[.5 .5 1];
w=[1 1 1];
seq=repmat([r;r;w;r;r;w;b;b;w;b;b;w],4,1); % light sequence
set([hg2L,hg2g],FaceC=seq(f,:))
% you are looking at the YZ plane
step=f/48*max(ylim)/3;
if f<27
hg.Matrix=makehgtform(translate=[v(1),7.7+step,0],yrotate=-pi/2,Scale=0.2); % rotate from the XY plane to the YZ plane and move to empty street
hg2.Matrix=makehgtform(translate=[v(1),6.3+step,0],yrotate=-pi/2,Scale=0.2);
else
hg2.Matrix=makehgtform(translate=[v(2),14.5-step,0],Scale=0.2,zrotate=pi,yrotate=-pi/2);
hg.Matrix=makehgtform(translate=[v(2),14.5-step-1,0],Scale=0.2,zrotate=pi,yrotate=-pi/2);
end
end
Animation
