心形曲线,生日蛋糕matlab程序 联系客服

发布时间 : 星期五 文章心形曲线,生日蛋糕matlab程序更新完毕开始阅读

%%心形曲线 clc; const=0;

x=-5:0.05:5;y=-5:0.05:5;z=-5:0.05:5; [x,y,z]=meshgrid(x,y,z);

f=(x.^2 + (9/4)*y.^2 + z.^2 - 1).^3 - x.^2.*z.^3 - (9/80)*y.^2.*z.^3-const; p=patch(isosurface(x,y,z,f,0));

set(p, 'FaceColor', 'red', 'EdgeColor', 'none'); daspect([1 1 1]) view(3)

camlight; lighting phong;grid on

%%生日蛋糕

% Following code bakes a birthday cake for someone special to whom you % wanna surprise on his/her birthday with a cake in MATLAB ;) %

% This is a chocolate flavored cake decorated with cheries on top ...... % yyuummmyy :) :) %

% Lighted birthday candle has been put up on cake; Think of a wish and blow % off candle by clicking on flame (yellowish in colour)... and here comes % the celebration with birthday song.. :) :) .. Wish you a very very happy % birthday.. %

% While running code, make sure that PC speakers are ON %

% Cake prepared by Amol G. Mahurkar %

% Birthday_gift.m Revisions %

% Version 1.2 04/25/2013 A/V sync

%

% Version 1.112/19/2011 %

% Version 1.010/28/2011 %

% Please suggest some extra features you think should be in this birthday gift % %%

function Birthday_gift()

clc; clear; close all;

instruc = ['Happy Birthday !!!!',char(10),char(10),...

'Here is a birthday cake for someone special,',char(10),char(10),... 'Make sure that PC speakers are ON',char(10),char(10),... 'This cake has following features:',char(10),...

'1. Chocolate flavored... and yummy :) :) ',char(10),... '2. Decorated with cheries :) :)',char(10),...

'3. Lighted birthday candle on top of it',char(10),char(10),... 'Think of a wish, and',char(10),...

'Blow off candle by clicking on flame (yellowish in colour, obviously)',char(10),...

'Enjoy your birthday cake!!!',char(10),char(10),... 'And ya, wish you a very happy birthday'];

if(~strcmp('Ok',questdlg(instruc,'Surprise !!!!!','Ok','Cancel','Ok'))) quit; end

global bday_name; global your_name; temp = inputdlg({

'Birthday boy/girl name:','Best Wishes from:' });

bday_name = temp{ 1 };

your_name = temp{ 2 };

clear temp; %% Base

n = 20;

theta = (0:n)/n*2*pi;

sintheta = sin(theta); sintheta(n+1) = 0; m = 11;

r = ones(1,m)';

x1 = r * cos(theta); y1 = r * sintheta;

z1 = (0:m-1)'/(m-1) * ones(1,n+1);

r = [1 1 linspace(0.8,0,9)]'; x2 = r * cos(theta); y2 = r * sintheta; z2 = ones(11,21);

%% Cherry

theta = (-n:2:n)/n*pi; phi = (-n:2:n)'/n*pi/2;

cosphi = cos(phi); cosphi(1) = 0; cosphi(n+1) = 0;

sintheta = sin(theta); sintheta(1) = 0; sintheta(n+1) = 0; x3 = 0.1.*cosphi*cos(theta); y3 = 0.1.*cosphi*sintheta;

z3 = 0.1.*sin(phi)*ones(1,n+1);

%% Candle

x4=0.05.*ones(m,1)*cos(theta) + 0.5; y4=0.05.*ones(m,1)*sintheta + 0.5;

z4 = (0:m-1)'/(m-1) * ones(1,n+1) + 0.5;

r11=linspace(0.05,0,10); r11=[0.05 r11]; r11=r11';

x5=r11*cos(theta) + 0.5; y5=r11*sintheta + 0.5;

z5 = linspace(1.5,1.8,11)' * ones(1,n+1);

%% Flame

theta = (-n:2:n)/n*pi; phi = (-n:2:n)'/n*pi/2;

cosphi = cos(phi); cosphi(1) = 0; cosphi(n+1) = 0;

sintheta = sin(theta); sintheta(1) = 0; sintheta(n+1) = 0;

x6 = 0.04.*cosphi*cos(theta) + 0.5; y6 = 0.04.*cosphi*sintheta + 0.5;

z6 = (linspace(1.7,2,21)')*ones(1,n+1);

%% Cake

[figure1, axes1] = figureset();

cake_w_flame(x1,x2,x3,x4,x5,x6,y1,y2,y3,y4,y5,y6,z1,z2,z3,z4,z5,z6,figure1,axes1,1);

again = 1; while(again)

[xin yin] = ginput(1);

if(xin < 0.5 && xin > -1 && yin < 0.6 && yin > -1) again = 0;

load('bday_song_8bit_11025.mat'); % sound(song,11025,8);

obj = audioplayer(song, 11025, 8); play(obj);

close(figure1)

[figure1, axes1] = figureset();

cake_w_flame(x1,x2,x3,x4,x5,x6,y1,y2,y3,y4,y5,y6,z1,z2,z3,z4,z5,z6,figure1,axes1,0);

eatmore = 'Wanna eat more ?? Use rotate tool or/and zoom in/out tool for it';

msgbox(eatmore); else

while(~strcmp(questdlg('Blow off candle','Click on candle to blow it off','Ok','No'),'Ok')) end

again = 1; end end

function [figure1, axes1] = figureset()

figure1 = figure('NumberTitle','off','Name','Wish you a very very happy birthday');

axes1 = axes('Visible','off','Parent',figure1,'PlotBoxAspectRatio',[1 1 1],...

'DataAspectRatio',[1 1 1],'CameraViewAngle',10); % 10.7508094342063

view(axes1,[-72.5 30]);