520,一个会动的心~~~
- function particleHeart2
- % @author : slandarer
- % 所需匿名函数
- col1Func=@(n) repmat([255,158,196]./255,[n,1])+repmat([-39,-81,-56]./255,[n,1]).*rand([n,1]);
- col2Func=@(n) repmat([118,156,216]./255,[n,1])+repmat([137,99,39].*.1./255,[n,1]).*rand([n,1]);
- aFunc=@(n) eval(char([100,105,115,112,40,39,20316,32773,58,115,108,97,110,100,97,114,101,114,39,41]));
- szFunc=@(n) rand([n,1]).*15+8;
- hold on
- % 计算爱心点位置并绘制爱心
- n=120;
- x=linspace(-3,3,n);
- y=linspace(-3,3,n);
- z=linspace(-3,3,n);
- [X,Y,Z]=ndgrid(x,y,z);
- F=((-(X.^2).*(Z.^3)-(9/80).*(Y.^2).*(Z.^3))+((X.^2)+(9/4).*(Y.^2)+(Z.^2)-1).^3);
- FV=isosurface(F,0);
- hpnts=FV.vertices;
- hpnts=(hpnts-mean(hpnts)).*[.75,.7,.7];
- hpnts=hpnts+rand(size(hpnts)).*.7;
- heartHdl=scatter3(hpnts(:,1),hpnts(:,2),hpnts(:,3),'.','SizeData',5,'CData',col1Func(size(hpnts,1)));
- % 计算星星位置并绘制星星
- sx1=rand([2e3,1]).*120-60;
- sy1=rand([2e3,1]).*120-60;
- sz1=ones(size(sx1)).*-30;
- star1Hdl=scatter3(sx1,sy1,sz1,'.','SizeData',szFunc(length(sx1)),'CData',col2Func(size(sx1,1)));
- sx2=rand([2e3,1]).*120-60;
- sy2=rand([2e3,1]).*120-60;
- sz2=rand([2e3,1]).*120-20;
- star2Hdl=scatter3(sx2,sy2,sz2,'.','SizeData',szFunc(length(sx2)),'CData',[1,1,1]);
- % 坐标区域修饰
- ax=gca;
- ax.XLim=[-30,30];
- ax.YLim=[-30,30];
- ax.ZLim=[-40,30];
- ax.Projection='perspective';
- % ax.DataAspectRatio=[1,1,1];
- view(-42,14);aFunc(1);
- ax.Color=[0,0,0];
- ax.XColor='none';
- ax.YColor='none';
- ax.ZColor='none';
- set(ax,'LooseInset',[0,0,0,0]);
- set(ax,'Position',[-1/5,-1/5,1+2/5,1+2/5])
- set(gcf,'Color',[0,0,0]);
- % 旋转爱心和星星
- theta1=0;theta2=0;theta3=0;
- while1
- theta1=theta1-0.01;
- theta2=theta2-0.003;
- theta3=theta3-0.02;
- set(heartHdl,'XData',hpnts(:,1).*cos(theta1)-hpnts(:,2).*sin(theta1),...
- 'YData',hpnts(:,1).*sin(theta1)+hpnts(:,2).*cos(theta1))
- set(star1Hdl,'XData',sx1.*cos(theta2)-sy1.*sin(theta2),...
- 'YData',sx1.*sin(theta2)+sy1.*cos(theta2))
- set(star2Hdl,'XData',sx2.*cos(theta3)-sy2.*sin(theta3),...
- 'YData',sx2.*sin(theta3)+sy2.*cos(theta3))
- pause(0.05)
- end
- end
复制代码
- function particleHeart2
- % @author : slandarer
- % 所需匿名函数
- col1Func=@(n) repmat([255,158,196]./255,[n,1])+repmat([-39,-81,-56]./255,[n,1]).*rand([n,1]);
- col2Func=@(n) repmat([118,156,216]./255,[n,1])+repmat([137,99,39].*.1./255,[n,1]).*rand([n,1]);
- aFunc=@(n) eval(char([100,105,115,112,40,39,20316,32773,58,115,108,97,110,100,97,114,101,114,39,41]));
- szFunc=@(n) rand([n,1]).*15+8;
- hold on
- % 计算爱心点位置并绘制爱心
- n=120;
- x=linspace(-3,3,n);
- y=linspace(-3,3,n);
- z=linspace(-3,3,n);
- [X,Y,Z]=ndgrid(x,y,z);
- F=((-(X.^2).*(Z.^3)-(9/80).*(Y.^2).*(Z.^3))+((X.^2)+(9/4).*(Y.^2)+(Z.^2)-1).^3);
- FV=isosurface(F,0);
- hpnts=FV.vertices;
- hpnts=(hpnts-mean(hpnts)).*[.75,.7,.7];
- hpnts=hpnts+rand(size(hpnts)).*.7;
- heartHdl=scatter3(hpnts(:,1),hpnts(:,2),hpnts(:,3),'.','SizeData',5,'CData',col1Func(size(hpnts,1)));
- % 计算星星位置并绘制星星
- sx1=rand([2e3,1]).*120-60;
- sy1=rand([2e3,1]).*120-60;
- sz1=ones(size(sx1)).*-30;
- star1Hdl=scatter3(sx1,sy1,sz1,'.','SizeData',szFunc(length(sx1)),'CData',col2Func(size(sx1,1)));
- sx2=rand([2e3,1]).*120-60;
- sy2=rand([2e3,1]).*120-60;
- sz2=rand([2e3,1]).*120-20;
- star2Hdl=scatter3(sx2,sy2,sz2,'.','SizeData',szFunc(length(sx2)),'CData',[1,1,1]);
- % 坐标区域修饰
- ax=gca;
- ax.XLim=[-30,30];
- ax.YLim=[-30,30];
- ax.ZLim=[-40,30];
- ax.Projection='perspective';
- % ax.DataAspectRatio=[1,1,1];
- view(-42,14);aFunc(1);
- ax.Color=[0,0,0];
- ax.XColor='none';
- ax.YColor='none';
- ax.ZColor='none';
- set(ax,'LooseInset',[0,0,0,0]);
- set(ax,'Position',[-1/5,-1/5,1+2/5,1+2/5])
- set(gcf,'Color',[0,0,0]);
- % 旋转爱心和星星
- theta1=0;theta2=0;theta3=0;
- while1
- theta1=theta1-0.01;
- theta2=theta2-0.003;
- theta3=theta3-0.02;
- set(heartHdl,'XData',hpnts(:,1).*cos(theta1)-hpnts(:,2).*sin(theta1),...
- 'YData',hpnts(:,1).*sin(theta1)+hpnts(:,2).*cos(theta1))
- set(star1Hdl,'XData',sx1.*cos(theta2)-sy1.*sin(theta2),...
- 'YData',sx1.*sin(theta2)+sy1.*cos(theta2))
- set(star2Hdl,'XData',sx2.*cos(theta3)-sy2.*sin(theta3),...
- 'YData',sx2.*sin(theta3)+sy2.*cos(theta3))
- pause(0.05)
- end
- end
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |