利用Matlab繪制好看的旋轉(zhuǎn)九邊形
PART.0 使用效果


PART.1 程序說(shuō)明
這個(gè)代碼主要復(fù)刻的Clayton Shonkwiler使用Wolfram繪制的作品(二十個(gè)旋轉(zhuǎn)的正九變形),據(jù)說(shuō)其靈感來(lái)源于Thomas Davis的一些作品,Clayton Shonkwiler的更多作品可以在這個(gè)地址查看
PART.2 完整代碼
function nonagon20
% @author:slandarer
% axes屬性設(shè)置
ax=gca;
hold on;axis equal;
ax.Position=[0 0 1 1];
ax.XLim=[-6,6];ax.YLim=[-6,6];
ax.XColor='none';ax.YColor='none';
ax.Color=[0,44,106]./255;
% 初始集合構(gòu)建
t=linspace(0,2*pi,9);
NGon=[cos(t'),sin(t')].*2;
NGonSet=repmat(NGon',[20,1]);
rotate18=arrayfun(@(k)[cos(pi/10),-sin(pi/10);sin(pi/10),cos(pi/10)]^k,0:19,'UniformOutput',false);
rotate18=blkdiag(rotate18{:});
NGonSet=rotate18*NGonSet;
% 漸變顏色矩陣創(chuàng)建
C1=[237,210,155]./255;
C2=[219,90,117]./255;
ct=linspace(0,1,11);
CList=[interp1([0,1],[C1(1),C2(1)],ct,'linear')',...
interp1([0,1],[C1(2),C2(2)],ct,'linear')',...
interp1([0,1],[C1(3),C2(3)],ct,'linear')'];
CList=[CList;flipud(CList(2:10,:))];CList=[CList(5:end,:);CList(1:4,:)];
% 初始圖像繪制
NGonHdl{20}=[];
for i=1:20
NGonHdl{i}=fill(NGonSet(i*2-1,:)+cos((i-1)*pi/10)*2,...
NGonSet(i*2,:)+sin((i-1)*pi/10)*2,CList(i,:),...
'FaceAlpha',.12,'LineWidth',1.3,'EdgeColor',CList(i,:));
end
% 旋轉(zhuǎn)矩陣
rotateMat=arrayfun(@(k)[cos(k),-sin(k);sin(k),cos(k)],ones([1,20]).*(2*pi/120),'UniformOutput',false);
rotateMat=blkdiag(rotateMat{:});
% 旋轉(zhuǎn)
for n=1:1000
NGonSet=rotateMat*NGonSet;
for i=1:20
NGonHdl{i}.XData=NGonSet(i*2-1,:)+cos((i-1)*pi/10)*2;
NGonHdl{i}.YData=NGonSet(i*2,:)+sin((i-1)*pi/10)*2;
end
pause(.05)
drawnow
end
end到此這篇關(guān)于利用Matlab繪制好看的旋轉(zhuǎn)九邊形的文章就介紹到這了,更多相關(guān)Matlab旋轉(zhuǎn)九邊形內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Matlab處理圖像后實(shí)現(xiàn)簡(jiǎn)單的人臉檢測(cè)
本文主要介紹一下如何使用matlab進(jìn)行圖像處理后實(shí)現(xiàn)人臉檢測(cè),感興趣的可以了解一下2021-11-11
C++使用異或運(yùn)算實(shí)現(xiàn)交換兩個(gè)數(shù)的值
交換兩個(gè)數(shù)的值,通常用利用一個(gè)變量來(lái)交換數(shù)值,異或交換兩個(gè)數(shù)的值是資源開(kāi)銷(xiāo)最小的方法,不需要中介數(shù),原理簡(jiǎn)單的來(lái)說(shuō)就是異或的負(fù)負(fù)得正2018-09-09
C++基本用法實(shí)踐之移動(dòng)語(yǔ)義詳解
移動(dòng)(move)語(yǔ)義是C++引入了一種新的內(nèi)存優(yōu)化,以避免不必要的拷貝,下面小編就來(lái)和大家簡(jiǎn)單聊聊C++中移動(dòng)語(yǔ)義的相關(guān)使用吧,希望對(duì)大家有所幫助2023-07-07
快速掌握VC6.0中各種宏注釋?xiě)?yīng)用(附圖)
為了方便別人或自己閱讀自己的程序,注釋是堅(jiān)決不可少的,一個(gè)漂亮的程序,不是在于你應(yīng)用的技術(shù)多么高深,而是能夠把高深的技術(shù)描述的清楚易懂2013-01-01
C++設(shè)計(jì)模式之裝飾模式(Decorator)
這篇文章主要為大家詳細(xì)介紹了C++設(shè)計(jì)模式之裝飾模式Decorator的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-03-03

