電子產業(yè)一站式賦能平臺

PCB聯盟網

搜索
查看: 90|回復: 0
收起左側

MATLAB |不給糖果就搗蛋

[復制鏈接]

193

主題

193

帖子

1532

積分

三級會員

Rank: 3Rank: 3

積分
1532
跳轉到指定樓層
樓主
發(fā)表于 2023-11-1 13:05:00 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
點擊上方藍字和“好玩的MATLAB”一起快樂玩耍吧!

好玩的matlab
帶你解鎖不一樣的matlab新玩法

萬圣節(jié)??到了,今天介紹一下怎么用 MATLAB 整活,喜歡此推文的小伙伴們記得點贊+關注+分享!【尊重作者勞動成果,轉載請注明推文鏈接和公眾號名】
效果圖



代碼繪制南瓜
  • clc;clear;close all;[X,Y,Z]=sphere(200);R=1+(-(1-mod(0:.1:20,2)).^2)/15;surf(R.*X,R.*Y,(.8+(0-(1:-.01:-1)'.^4)*.2).*Z.*R,'FaceC',[ 1 0.4588 0.0941],'EdgeC','n')axis('equal','off')material([ .6, .9, .3, 2, .5 ])lighting gcamlight

    繪制無臉男小鬼
  • clc;clear;close allfig=figure('Position',[476 224 672 642]);ax=gca;ax.Color='none';ax.YLim=[0,15];ax.XLim=[-3,14];ax.Box='off';ax.XColor='none';ax.YColor='none';axis equal;hold onpause(0.1)[X, Y] = meshgrid(linspace(1, 0, 200));image([-3, 14], [0, 15], Y*255);colormap(gray)pause(0.1)ellipse = EllipsePlotter('a', 4, 'b', 6, 'x', 5.4, 'y', 6.2, ...    'plotType', 'fill', 'fillColor', [.4,.4,.4], 'rotation', 0, ...    'angleRange',[-25,205],'alpha',1,'lineWidth',6,'lineColor',[1,1,1]*0.9);ellipse.plotEllipse();d=[0 -0.3 -0.4 -0.6 -0.4 -0.3 0];for i=1:7    ellipse = EllipsePlotter('a',1.2, 'b', 3.3, 'x', 2.7+(i-1)*0.9, 'y', 5.5+d(i), ...        'plotType', 'fill', 'fillColor',[.4,.4,.4], 'rotation', 0, ...        'angleRange',[-200,20],'alpha',1,'lineWidth',6,'lineColor','none');    ellipse.plotEllipse();end% 臉pause(0.3)FaceColor=[1.0 0.9627 0.9235];ellipse = EllipsePlotter('a',3, 'b', 2.8, 'x',5.4, 'y',9, ...    'plotType', 'fill', 'fillColor',FaceColor, 'rotation', 0, ...    'angleRange',[0,360],'alpha',1,'lineWidth',2,'lineColor','none');ellipse.plotEllipse();% 眉毛、腮紅、嘴pause(0.3)ellipse = EllipsePlotter('a',0.3, 'b',1, 'x',3.9, 'y',10.2, ...    'plotType', 'fill', 'fillColor',[1.0 0.65 0.63], 'rotation', 15, ...    'angleRange',[0,360],'alpha',1,'lineWidth',2,'lineColor','none');ellipse.plotEllipse();
    ellipse = EllipsePlotter('a',0.3, 'b',1, 'x',6.8, 'y',10.4, ...    'plotType', 'fill', 'fillColor',[1.0 0.65 0.63], 'rotation', 160, ...    'angleRange',[0,360],'alpha',1,'lineWidth',2,'lineColor','none');ellipse.plotEllipse();ellipse = EllipsePlotter('a',0.3, 'b',1, 'x',7, 'y',7.8, ...    'plotType', 'fill', 'fillColor',[1.0 0.65 0.63], 'rotation', 0, ...    'angleRange',[-200,20],'alpha',1,'lineWidth',2,'lineColor','none');ellipse.plotEllipse();ellipse = EllipsePlotter('a',0.3, 'b',1, 'x',4, 'y',7.6, ...    'plotType', 'fill', 'fillColor',[1.0 0.65 0.63], 'rotation', -10, ...    'angleRange',[-200,20],'alpha',1,'lineWidth',2,'lineColor','none');ellipse.plotEllipse();pause(0.3)ellipse = EllipsePlotter('a',.84, 'b',1.1, 'x',3.9, 'y',8.9, ...    'plotType', 'fill', 'fillColor',FaceColor, 'rotation', 0, ...    'angleRange',[0,360],'alpha',1,'lineWidth',2,'lineColor','none');ellipse.plotEllipse();ellipse = EllipsePlotter('a',.84, 'b',1.2, 'x',7, 'y',9, ...    'plotType', 'fill', 'fillColor',FaceColor, 'rotation', 0, ...    'angleRange',[0,360],'alpha',1,'lineWidth',2,'lineColor','none');ellipse.plotEllipse();%嘴巴pause(0.3)ellipse = EllipsePlotter('a',.3, 'b',.5, 'x',5.3, 'y',7.9, ...    'plotType', 'fill', 'fillColor',[0.9 0 0], 'rotation', 0, ...    'angleRange',[-180,0],'alpha',1,'lineWidth',2,'lineColor','none');ellipse.plotEllipse();
    ellipse = EllipsePlotter('a',.5, 'b',.25, 'x',5.3, 'y',8, ...    'plotType', 'fill', 'fillColor',FaceColor, 'rotation', 0, ...    'angleRange',[-180,0],'alpha',1,'lineWidth',2,'lineColor','none');ellipse.plotEllipse();%眼袋pause(0.2)ellipse = EllipsePlotter('a',0.3, 'b',0.1, 'x',3.9, 'y',8.2, ...    'plotType', 'fill', 'fillColor',[1 1 1]*0.8, 'rotation', 0, ...    'angleRange',[0,360],'alpha',1,'lineWidth',2,'lineColor','none');ellipse.plotEllipse();ellipse = EllipsePlotter('a',0.3, 'b',0.11, 'x',7, 'y',8.2, ...    'plotType', 'fill', 'fillColor',[1 1 1]*0.8, 'rotation', 0, ...    'angleRange',[0,360],'alpha',1,'lineWidth',2,'lineColor','none');ellipse.plotEllipse();% 眼睛pause(0.3)ellipse = EllipsePlotter('a',0.7, 'b',0.6, 'x',3.9, 'y',9.1, ...    'plotType', 'fill', 'fillColor',[0 0 0], 'rotation', 0, ...    'angleRange',[0,360],'alpha',1,'lineWidth',2,'lineColor','none');ellipse.plotEllipse();ellipse = EllipsePlotter('a',0.7, 'b',0.6, 'x',7, 'y',9.1, ...    'plotType', 'fill', 'fillColor',[0 0 0], 'rotation', 0, ...    'angleRange',[0,360],'alpha',1,'lineWidth',2,'lineColor','none');ellipse.plotEllipse();% 心pause(0.3)t=0:0.025:2*pi;x=(16*sin(t).^3)/10+5.5;y=(13*cos(t)-5*cos(2*t)-2*cos(3*t)-cos(4*t))/10+4.8;fill(x,y,'r','edgecolor','r');%風車pause(0.3)plot([0 0.2],[9.5 7],'LineWidth',3,'Color',[0,0,1,0.5]) colors = {'r', 'g', 'b', 'y';'c', 'm', 'g','c'};L = 0.8;center = [0,9.5]; % 定義風車的圓心T=[0 pi/3];for j = 1:4    for i=1:2        theta1 = (j-1) * pi/2+T(i);        theta2 = theta1 + pi/2;        P0 = center;        P1 = center + L * [cos(theta1), sin(theta1)];        P2 = center + L * [cos(theta2), sin(theta2)];        Psharp = (P1 + P2) / 2;        fill([P0(1), P1(1), Psharp(1)], [P0(2), P1(2), Psharp(2)], colors{i,j},'EdgeColor','none','FaceAlpha',0.8);    endend%手pause(0.3)ellipse = EllipsePlotter('a',3, 'b',0.8, 'x',8.5, 'y',6, ...    'plotType', 'fill', 'fillColor',[.4 .4 .4], 'rotation', -30, ...    'angleRange',[100,250],'alpha',1,'lineWidth',2,'lineColor',[1,1,1]*0.6);ellipse.plotEllipse();ellipse = EllipsePlotter('a',3, 'b',0.8, 'x',8.7, 'y',6.1, ...    'plotType', 'fill', 'fillColor',[.4 .4 .4], 'rotation', -30, ...    'angleRange',[100,250],'alpha',1,'lineWidth',2,'lineColor','none');ellipse.plotEllipse();pause(0.3)ellipse = EllipsePlotter('a',3, 'b',0.8, 'x',2.6, 'y',6, ...    'plotType', 'fill', 'fillColor',[.4 .4 .4], 'rotation',20, ...    'angleRange',[100,270],'alpha',1,'lineWidth',2,'lineColor',[1,1,1]*0.6);ellipse.plotEllipse();ellipse = EllipsePlotter('a',3, 'b',0.8, 'x',2.7, 'y',5.95, ...    'plotType', 'fill', 'fillColor',[.4 .4 .4], 'rotation',20, ...    'angleRange',[100,270],'alpha',1,'lineWidth',2,'lineColor','none');ellipse.plotEllipse();pause(0.3)tex=sprintf('不給糖果
      就搗蛋');text(8,13,tex,'FontSize',30,'FontWeight','bold','Color','w');

    其中繪制風車代碼:
  • hold onplot([0 0.2],[9.5 7],'LineWidth',3,'Color',[0,0,1,0.5]) colors = {'r', 'g', 'b', 'y';'c', 'm', 'g','c'};L = 0.8;center = [0,9.5]; % 定義風車的圓心T=[0 pi/3];for j = 1:4    for i=1:2        theta1 = (j-1) * pi/2+T(i);        theta2 = theta1 + pi/2;        P0 = center;        P1 = center + L * [cos(theta1), sin(theta1)];        P2 = center + L * [cos(theta2), sin(theta2)];        Psharp = (P1 + P2) / 2;        fill([P0(1), P1(1), Psharp(1)], [P0(2), P1(2), Psharp(2)], colors{i,j},'EdgeColor','none','FaceAlpha',0.8);    endend

    其中愛心代碼:
  • t=0:0.025:2*pi;x=(16*sin(t).^3)/10+5.5;y=(13*cos(t)-5*cos(2*t)-2*cos(3*t)-cos(4*t))/10+4.8;fill(x,y,'r','edgecolor','r');

    其中 EllipsePlotter類函數代碼如下
  • classdef EllipsePlotter    properties        a = 1;        b = 1;        x = 0;        y = 0;        angleRange = [0 2*pi];        rotation = 0;        lineColor = 'b';        lineWidth = 1;        plotType = 'plot';        fillColor = 'r';        alpha = 1;    end    methods        function obj = EllipsePlotter(varargin)            % Constructor            if nargin > 0                for i = 1:2:nargin                    obj.(varargin{i}) = varargin{i+1};                end            end            startRadian = obj.angleRange(1) * pi / 180;            endRadian = obj.angleRange(2) * pi / 180;            theta = startRadian:pi/100:endRadian;        end        function plotEllipse(obj)            startRadian = obj.angleRange(1) * pi / 180;            endRadian = obj.angleRange(2) * pi / 180;            theta = startRadian:pi/100:endRadian;            X = obj.a * cos(theta);            Y = obj.b * sin(theta);            % 旋轉坐標            rotationMatrix = [cosd(obj.rotation), -sind(obj.rotation); sind(obj.rotation), cosd(obj.rotation)];            xyRotated = [X; Y]' * rotationMatrix;            % 將旋轉后的橢圓平移到指定的位置            XY(:,1) = xyRotated(:,1) + obj.x;            XY(:,2) = xyRotated(:,2) + obj.y;            % 根據 plotType 來繪制橢圓            if strcmp(obj.plotType, 'plot')                plot(XY(:,1), XY(:,2), '-', 'Color', obj.lineColor, 'LineWidth', obj.lineWidth);                hold on; axis equal            elseif strcmp(obj.plotType, 'fill')                fill(XY(:,1), XY(:,2), obj.fillColor, 'EdgeColor', obj.lineColor, 'FaceAlpha', obj.alpha, 'LineWidth', obj.lineWidth);                hold on; axis equal            else                error('無效的 plotType 參數!');            end        end    endend
    屬性 (properties)這些屬性定義了橢圓的參數和繪圖樣式。
    a, b: 橢圓的主軸和次軸的長度。
    x, y: 橢圓的中心位置。
    angleRange: 繪制橢圓的角度范圍。
    rotation: 橢圓的旋轉角度。
    lineColor: 橢圓邊界的顏色。
    lineWidth: 橢圓邊界的線寬。
    plotType: 繪圖類型,可以是 'plot' 或 'fill'。
    fillColor: 如果 plotType 是 'fill',則此屬性定義填充顏色。
    alpha: 填充的透明度。
    方法 (methods)這些方法定義了類的功能。
    構造函數 (EllipsePlotter):
    當創(chuàng)建這個類的對象時,它會被調用。
    它接受一系列的名稱-值對參數,允許在創(chuàng)建對象時設置屬性。
    它目前只計算了一個角度范圍,但并沒有使用這個范圍做任何其他事情。
  • plotEllipse:
    該方法根據對象的屬性值繪制一個橢圓。
    它首先計算了橢圓上的點的坐標。
    然后根據 rotation 屬性旋轉這些點。
    接著將旋轉后的點平移到 x 和 y 屬性指定的位置。
    最后,根據 plotType 屬性選擇繪制方式:'plot' 會繪制橢圓的輪廓,而 'fill' 會填充橢圓。
    [/ol]這個類可以使用戶輕松地創(chuàng)建和定制橢圓的繪圖,而不必每次都重復相同的計算和繪圖代碼。例如,用戶可以輕松地更改橢圓的大小、位置、顏色和旋轉,并立即看到結果。- -THE END- -
    源碼下載:gitee下載:https://gitee.com/iDMatlab/ghost

    QQ群下載:

    參考資料:
    【1】【好玩的源碼】MATLAB畫冰墩墩【2】【好玩的源碼】兒童節(jié)快樂!送你一只可愛的小豬佩琪



    送書活動



    包郵贈送 「北京大學出版社贊助《AI時代Excel數據分析提升之道》AI時代Excel數據分析提升之道:知識精進+學習答疑+上機實訓+綜合實戰(zhàn)+ChatGPT應用,零基礎入門,極速提升數據分析效率!
  • 零基礎入門寶典,由淺入深講解,無須額外的背景知識即可學習掌握。
  • 內容系統全面,可幫助讀者快速了解使用Python進行Excel數據分析的基本語法并掌握開發(fā)能力。
  • 理論與實踐相結合,每個理論都有對應的代碼示例,讀者參考代碼示例完成編寫,就可以看到實踐效果。
  • 本書配有實訓與問答,方便讀者閱讀后盡快鞏固知識點,做到舉一反三、學以致用。
  • AI前沿產品ChatGPT+Python進行Excel數據分析,大幅學習和分析的效率
    了解更多
    【抽獎方式及滿足條件】:
    1.關注「好玩的MATLAB 」公眾號和視頻號

    2.給本文點【】+【在看】;
    3.留言區(qū)評論點贊最多的前3名。
    4.本活動只針對從未獲過獎的同學,之前獲過獎的小伙伴,不用參加。
    同時滿足上述4個條件的讀者朋友,包郵贈送一本。
    【開獎時間】:2023年11月2日中午12點
    【領獎方式】:在開獎時加小編私人微信:idmatlab
    掃一掃加管理員微信

  • 回復

    使用道具 舉報

    發(fā)表回復

    您需要登錄后才可以回帖 登錄 | 立即注冊

    本版積分規(guī)則


    聯系客服 關注微信 下載APP 返回頂部 返回列表