有趣之matlab-烟花

待整合1 2 3

  1. 动态

有趣编程之11

静态 逼真

3 .m文件路径下放back1.jpg back4.jpg…背景照片
点击screen 就会有小白点升起,爆炸

function yanhuamoban()clear all;%定义全局变量global ah ;%坐标轴句柄global styleNum ;%爆炸图案样式global multiColor; %多颜色变换global color;%烟花颜色global v0;%烟花爆炸速度global n; %粒子数量global g;%粒子重力加速度%变量初始化开始multiColor = 0;styleNum = 3;color = [1 1 0];v0 = 250;   %烟花爆炸时的速度n = 2000;%粒子shumug=1000;%变量初始化结束%GUI部分开始fig = figure('units','normalized','position',[0.1 0.1 0.6 0.8],...'menubar','none','numberTitle','off','Name','烟花欣赏','WindowButtonDownFcn',@yanhua...);%菜单file_menu = uimenu(fig,'Label','文件(&f)');sub_file_menu1 = uimenu(file_menu,'Label','退出(&q)','CallBack',@file_menu_callback);style_menu = uimenu(fig,'Label','爆炸风格(&s)');sub_style_menu1 = uimenu(style_menu,'Label','风格(&1)','CallBack',@style_menu_callback);sub_style_menu2 = uimenu(style_menu,'Label','风格(&2)','CallBack',@style_menu_callback);sub_style_menu3 = uimenu(style_menu,'Label','风格(&3)','CallBack',@style_menu_callback);sub_style_menu4 = uimenu(style_menu,'Label','风格(&4)','CallBack',@style_menu_callback);sub_style_menu5 = uimenu(style_menu,'Label','风格(&5)','CallBack',@style_menu_callback);sub_style_menu6 = uimenu(style_menu,'Label','风格(&6)','CallBack',@style_menu_callback);picture_menu = uimenu(fig,'Label','背景图片(&p)');sub_picture_menu1 = uimenu(picture_menu,'Label','图片(&1)','CallBack',@picture_menu_callback);sub_picture_menu2 = uimenu(picture_menu,'Label','图片(&2)','CallBack',@picture_menu_callback);sub_picture_menu3 = uimenu(picture_menu,'Label','图片(&3)','CallBack',@picture_menu_callback);sub_picture_menu4 = uimenu(picture_menu,'Label','图片(&4)','CallBack',@picture_menu_callback);sub_picture_menu5 = uimenu(picture_menu,'Label','图片(&5)','CallBack',@picture_menu_callback);color_menu = uimenu(fig,'Label','烟花颜色(&c)');sub_color_menu1 = uimenu(color_menu,'Label','黄色(&1)','CallBack',@color_menu_callback);sub_color_menu2 = uimenu(color_menu,'Label','紫红色(&2)','CallBack',@color_menu_callback);sub_color_menu3 = uimenu(color_menu,'Label','青色(&3)','CallBack',@color_menu_callback);sub_color_menu4 = uimenu(color_menu,'Label','红色(&4)','CallBack',@color_menu_callback);sub_color_menu5 = uimenu(color_menu,'Label','绿色(&5)','CallBack',@color_menu_callback);sub_color_menu6 = uimenu(color_menu,'Label','蓝色(&6)','CallBack',@color_menu_callback);sub_color_menu7 = uimenu(color_menu,'Label','白色(&7)','CallBack',@color_menu_callback);sub_color_menu8 = uimenu(color_menu,'Label','五彩变换(&8)','CallBack',@color_menu_callback);%按钮面板color_button_group = uibuttongroup(fig,'Title','颜色调节面板','Position',[0.83,0.55,0.16,0.44]);speed_button_group = uibuttongroup(fig,'Title',regexprep('速度调节面板(num)','num',num2str(v0)),'Position',[0.83,0.36,0.16,0.185],'Tag','speed_panel');number_button_group = uibuttongroup(fig,'Title',regexprep('数量调节面板(num)','num',num2str(n)),'Position',[0.83,0.005,0.16,0.35],'Tag','ammount_panel');%颜色微调滑动条red_slider = uicontrol(fig,'Style','slider','String','red','Position',[695,450,25,140],'Min',0,'Max',1,'Value',1,'backgroundColor',[1,0,0],'CallBack',@slider_callback);green_slider = uicontrol(fig,'Style','slider','String','green','Position',[735,450,25,140],'Min',0,'Max',1,'Value',1,'backgroundColor',[0,0,1],'CallBack',@slider_callback);blue_slider = uicontrol(fig,'Style','slider','String','blue','Position',[775,450,25,140],'Min',0,'Max',1,'Value',0,'backgroundColor',[0,1,0],'CallBack',@slider_callback);%颜色参数静态文本color_text = uicontrol(fig,'Style','text','Position',[690,395,115,50],'Tag','color_text',...'String',char('red=1','blue=1','green=0'),'backgroundColor',[1,0.95,0.87],'FontSize',10,'HorizontalAlignment','left');%颜色演示面板color_panel = uipanel(fig,'Title','颜色演示面板','BackgroundColor',color,'Units','pixels','Position',[690,345,115,40]);%修改速度按钮fast_button = uicontrol(fig,'Style','pushbutton','Position',[700,280,100,40],'FontSize',10,'String','加快','CallBack',@button_callback);slow_button = uicontrol(fig,'Style','pushbutton','Position',[700,230,100,40],'FontSize',10,'String','减慢','CallBack',@button_callback);%修改数量按钮increase_button = uicontrol(fig,'Style','pushbutton','Position',[700,160,100,40],'FontSize',10,'String','增多','CallBack',@button_callback);decrease_button = uicontrol(fig,'Style','pushbutton','Position',[700,110,100,40],'FontSize',10,'String','减少','CallBack',@button_callback);modNum_button = uicontrol(fig,'Style','pushbutton','Position',[700,60,100,40],'FontSize',10,'String','手动调整数量','CallBack',@button_callback);modG_button = uicontrol(fig,'Style','pushbutton','Position',[700,10,100,40],'FontSize',10,'String','手动调整加速度','CallBack',@button_callback);axes('DrawMode','fast','position',[0,0,0.8,1]);II=imread('back4.jpg');image(II)ah = axes('DrawMode','fast','Color','none','position',[0,0,0.8,1]);axis([-200 420 1 410])%设置坐标轴的范围grid off%GUI部分结束hold on%烟花主控函数,每次点击鼠标按钮监听器都会调用此函数。function yanhua(src,event)cp = get(ah,'CurrentPoint'); % 得到点击点的坐标xt = cp(1,1);yt = cp(1,2);if(xt < 420)%若点击在按钮面板则不放烟花launch(xt,yt)%烟花发射函数endend
end  %主函数调用结束%colormap(hot)
%烟花发射函数
function launch(xt,yt)x=xt;y=0;H=plot(x,y,'w.');      %以白色,点来绘制图像。set(H,'EraseMode','xor','MarkerSize',25)%擦除式绘图,通过在极短的时间里不断绘制新点坐标,擦出旧点坐标来实现烟花向上发射的运动效果T = timer('TimerFcn',@timer_display1,'StopFcn',@stopFcn1,'TasksToExecute',50,'Period',0.005,'ExecutionMode','fixedSpacing');%非阻塞式定时器,以0.005秒为间隔调用TimerFcn,共调用50次。调用玩后会启动StopFcn函数,进行清尾工作,如清楚发射点图像,初始化烟花爆炸的定时器等。而烟花发射的运动,就是通过在这50次的重复调用中,不断更新点的坐标来实现的。T.userData = {H,xt,yt,1};%定时器对象的属性。在定时函数里使用。定时器函数是不变的,但在重复调用中要实现点坐标的改变,就要通过改变定时器对象的对象属性才行。%为什么要用对象属性而不是函数内定义的局部变量?因为局部变量在每次函数调用完毕就会被销毁,不能实现类似于静态变量的效果在下次重复调用中生效。那为什么不适用全局变量?因为全局变量是共用的,我的定时器A能用,定时器B也能用,A修改了这个变量,B中也生效了,这就有“线程安全性”问题了。start(T);%启动定时器
end
function timer_display1(obj,event)userData = obj.userData;%获取对象数据H = userData{1};x = userData{2};yt = userData{3};i = userData{4};y=i/50*yt;%执行50次,就到了鼠标点击位置,预备爆炸了。这个运动模型可以结合实际的物理模型做进一步优化,感兴趣的同学不妨试试。set(H,'XData',x,'YData',y)%更新烟花坐标drawnow;%重画页面,使烟花"H"出现在新位置i=i+1;%这是控制烟花位移的关键obj.userData = {H,x,yt,i};%更新对象数据,再下次重复调用时再取出使用
endfunction stopFcn1(obj,event)%定时器1完成了它的50次调用使命,使烟花(点)到达爆炸处(鼠标位置),这个烟花(点)在这里被消除,然后开始了烟花爆炸的定时器初始化、启动工作global n;global color;userData = obj.userData;H = userData{1}xt = userData{2};yt = userData{3};x=-20;y=-20;set(H,'XData',x,'YData',y);%上述程序使得烟花到达鼠标的位置后消失在视野内%*************烟花的爆炸过程    x=zeros(n,1);%爆炸后的颗粒数为ny=zeros(n,1);h=plot(x,y,'.');%烟花爆炸后的形状set(h,'Color',color);set(h,'erasemode','xor','MarkerSize',5)T = timer('TimerFcn',@timer_display2,'StopFcn',@stopFcn2,'TasksToExecute',40,'Period',0.05,'ExecutionMode','fixedSpacing');T.userData = {h,xt,yt,0};start(T);
end
function timer_display2(obj,event)global n v0 styleNum multiColor g;userData = obj.userData;h = userData{1};x0 = userData{2};y0 = userData{3};t = userData{4};theta=rand(n,1)*2*pi;%粒子的仰角fy=rand(n,1)*2*pi;%粒子的方位角theta1=round(12*rand(n,1))/6*pi;for i=1:n %绘制粒子下落过程,switch(styleNum)%图案判定,通过菜单修改全局变量控制case 1x(i)=2*v0*cos(fy(i))*cos(theta(i)+t*pi)*t+x0;y(i)=1.2*v0*cos(fy(i))*sin(theta(i)+i*pi)*t-g*t.^2+y0;case 2if(mod(theta(i),0.4*pi)<=0.1*pi)x(i)=2*v0*cos(fy(i))*cos(theta(i)-4*t*pi)*t+x0;y(i)=1.2*v0*cos(fy(i))*sin(theta(i)-4*t*pi)*t-g*t.^2+y0;else x(i)=(mod(theta(i),0.4*pi)*2.5/pi+0.4)*2*v0*cos(fy(i))*cos(theta(i)-4*t*pi)*t+x0;y(i)=(mod(theta(i),0.4*pi)*2.5/pi+0.4)*1.2*v0*cos(fy(i))*sin(theta(i)-4*t*pi)*t-g*t.^2+y0;endcase 3x(i)=2*v0*cos(fy(i))*cos(theta(i)+i*t*pi)*t+x0;y(i)=1.2*v0*cos(fy(i))*sin(theta(i)+i*t*pi)*t-g*t.^2+y0;case 4x(i)=0.8*fy(i)/pi*2*v0*cos(fy(i))*cos(theta(i)+i*pi)*t+x0;y(i)=0.8*fy(i)/pi*(1.2*v0*cos(fy(i))*sin(theta(i)+i*pi)*t-g*t.^2)+y0;case 5x(i)=4*v0*cos(fy(i))*cos(theta1(i))*t+x0;y(i)=(4*v0*cos(fy(i))*sin(theta1(i)-cos(fy(i))*cos(theta1(i))*0.3*t*pi)*t-4*t.^2)+y0;case 6                       x(i)=v0*cos(fy(i))*cos(theta1(i)+4*t*pi)*t+x0;y(i)=v0*cos(fy(i))*sin(theta1(i))*t-g*t.^2+y0;    endendset(h,'xdata',x,'ydata',y);if(multiColor == 1)set(h,'Color',rand(1,3));enddrawnow;t = t + 0.01;obj.userData = {h,x0,y0,t};
end
function stopFcn2(obj,event)%下述程序使爆炸的烟花消失global n;userData = obj.userData;h = userData{1};x=zeros(n,1);y=zeros(n,1);set(h,'xdata',x,'ydata',y);
end%hObject  eventdata handles
%按钮回调函数
function button_callback(object,data,handles)global v0 n g;switch(object.String)case '加快'v0 = v0 + 50;speed_panel = findobj(gcf,'Tag','speed_panel');speed_panel.Title = regexprep(speed_panel.Title,'\d*',num2str(v0));%正则表达式替换case '减慢'v0 = v0 - 50;speed_panel = findobj(gcf,'Tag','speed_panel');speed_panel.Title = regexprep(speed_panel.Title,'\d*',num2str(v0));%正则表达式替换case '增多'n = n + 100;ammount_panel = findobj(gcf,'Tag','ammount_panel');ammount_panel.Title = regexprep(ammount_panel.Title,'\d*',num2str(n));%正则表达式替换case '减少'n = n - 100;ammount_panel = findobj(gcf,'Tag','ammount_panel');ammount_panel.Title = regexprep(ammount_panel.Title,'\d*',num2str(n));%正则表达式替换case '手动调整数量'ammount_input = inputdlg('请输入爆炸后烟花颗粒的数量','修改烟花数量',1);num=str2num(ammount_input{1});if isempty(num)errordlg('必须输入有效数字','错误');elsen = num;ammount_panel = findobj(gcf,'Tag','ammount_panel');ammount_panel.Title = regexprep(ammount_panel.Title,'\d*',num2str(n));%正则表达式替换endcase '手动调整加速度'ammount_input = inputdlg(strcat('请输入爆炸后烟花加速度值,当前值为:',num2str(g)),'修改加速度',1);num=str2num(ammount_input{1});if isempty(num)errordlg('必须输入有效数字','错误');elseg = num;endend
end
%烟花样式改变菜单
function style_menu_callback(object,data,handles)global styleNum;number = regexp(object.Label,'\d','match');styleNum = str2num(number{1});
end
function file_menu_callback(object,data,handles)switch(object.Label)case '退出(&q)'close(gcf);end
end
function picture_menu_callback(object,data,handles)global ah;number = regexp(object.Label,'\d','match');imageName = strcat(strcat('back',number),'.jpg');axes('DrawMode','fast','position',[0,0,0.8,1]);II=imread(imageName{1});image(II);ah = axes('DrawMode','fast','Color','none','position',[0,0,0.8,1]);axis([-200 420 1 410])%设置坐标轴的范围grid offhold on;
end
function color_menu_callback(object,data,handles)global color multiColor;disp(object.Label);multiColor = 0;%初始化颜色状态switch(object.Label)case '黄色(&1)'color = [1 1 0];case '紫红色(&2)'color = [1 0 1];case '青色(&3)'color = [0 1 1];case '红色(&4)'color = [1 0 0];case '绿色(&5)'color = [0 0 1];case '蓝色(&6)'color = [0 1 0];case '白色(&7)'color = [1 1 1];case '五彩变换(&8)'color = [0 0 0];multiColor = 1; endparseColor(color);
endfunction slider_callback(obj,event)global color ;red_slider = findobj(gcf,'String','red');blue_slider = findobj(gcf,'String','blue');green_slider = findobj(gcf,'String','green');color = [red_slider.Value,blue_slider.Value,green_slider.Value];parseColor(color);
end
function[rbgStr] = parseColor(color)color_text = findobj(gcf,'Tag','color_text');rbgStr = char(strcat('red=',num2str(color(1))),...strcat('blue=',num2str(color(2))),...strcat('green=',num2str(color(3))));color_text.String = rbgStr;color_panel = findobj(gcf,'Title','颜色演示面板');color_panel.BackgroundColor = color;
end

参考博文

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/746571.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Win11安装Plsql140报错2503

一、安装异常 二、解决办法 出现上述问题&#xff0c;主要是因为msi包安装的权限问题&#xff0c;使用管理员权限安装即解决 。cmd控制台以管理员身份打开WINR&#xff09;->(SHIFTCTRLRNTER)&#xff0c;进入到msi安装包目录下&#xff0c;以管理员身份安装即可&#xff1…

mysql数据库:使用 bash脚本 + 定时任务 自动备份数据

mysql数据库&#xff1a;使用 bash脚本 定时任务 自动备份数据 1、前言2、为什么需要自动化备份&#xff1f;3、编写备份脚本4、备份脚本授权5、添加定时任务6、重启 crond / 检查 crond 服务状态7、备份文件检查 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏…

Spring MVC共享域对象操作

1. 属性&#xff08;共享&#xff09;域介绍 在 JavaWeb 中&#xff0c;共享域指的是在 Servlet 中存储数据&#xff0c;以便在同一 Web 应用程序的多个组件中进行共享和访问。常见的共享域有四种&#xff1a;ServletContext、HttpSession、HttpServletRequest、PageContext。…

LeetCode28.找出字符串中第一个匹配项

28.找出字符串中第一个匹配项 给你两个字符串 haystack 和 needle &#xff0c;请你在 haystack 字符串中找出 needle 字符串的第一个匹配项的下标&#xff08;下标从 0 开始&#xff09;。如果 needle 不是 haystack 的一部分&#xff0c;则返回 -1 。 示例 1&#xff1a; 输入…

C++中的C标准库、注释和条件编译

C中的C标准库、注释和条件编译 C标准库 C作为一种在C语言基础上发展起来的编程语言&#xff0c;保留了对C语言标准库的完整支持。这些C标准库提供了一系列的通用功能&#xff0c;如输入输出处理、字符串操作、数学计算等&#xff0c;允许C程序员利用已经熟悉的库来开展工作。…

虾皮Shopee根据ID取商品详情API

在构建电商平台的第三方应用或服务时&#xff0c;开发者经常需要通过编程方式获取商品的详细信息。对于虾皮Shopee平台来说&#xff0c;其提供的API接口使得这一需求得以实现。本文将详细介绍如何调用虾皮Shopee的API接口&#xff0c;根据商品ID获取其商品详情。 准备工作 在…

“优化消费环境 维护消费者权”荥阳市城关乡社工站开展3·15宣传志愿活动

又是一年“315”&#xff0c;为提高辖区群众消费维权意识&#xff0c;让他们可以学会运用政策法律知识维护自身合法权益&#xff0c;同时也为营造出辖区良好营商环境。2024年3月15日&#xff0c;在荥阳市民政局、荥阳市市场监督管理局、城关乡人民政府的支持下&#xff0c;城关…

“值此春意,共享蓝天”—携手植新绿·静待成荫时

种竹交加翠&#xff0c;栽桃烂漫红。——唐杜甫《春日江村》 春风十里&#xff0c;万物生长。春风吹拂绿色现&#xff0c;树吐嫩芽花鲜艳。植树正是好季节&#xff0c;男女老少齐挥铲。种下棵棵小树苗&#xff0c;辛勤培育勤浇灌。来年长成苍天木&#xff0c;绿树成荫美景见。 …

基于ElasticSearch存储海量AIS数据:时空立方体索引篇

文章目录 引言I 时间维切分II 空间范围切分引言 索引结构制约着查询请求的类型和处理方式,索引整体架构制约着查询请求的处理效率。随着时间推移,AIS数据在空间分布上具备局部聚集性,如 果简单地将所有AIS数据插入一个索引结构,随着数据量增长,索引的更新效率、查询效率及…

「字幕之美:解析硬、软、外挂,探寻视频世界的无声艺术」

硬字幕、软字幕与外挂字幕&#xff1a;概述 硬字幕、软字幕和外挂字幕是视频内容中常见的三种字幕形式&#xff0c;它们在提供文字信息的同时&#xff0c;为观众提供了更丰富的观看体验。下面将对这三种字幕进行概述&#xff1a; 硬字幕&#xff08;Hard Subtitles&#xff0…

RabbitMQ 模拟实现【六】:程序模拟实现

文章目录 模拟实现模拟消费者模拟生产者效果展示 启动结果如下&#xff1a; ![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/71841546ad8043f1bd51e4408df791de.png)![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/f6e3e72ff9a4483c978ec48e24f075c2.p…

OceanBase原理之内存管理

第1章 前言 1.1 多租户管理简介 OceanBase数据库中&#xff0c;应用了单集群多租户的设计&#xff0c;使得一个集群内能够创建多个彼此独立的租户。在OceanBase数据库&#xff0c;租户成为了资源分配的单位&#xff0c;同时还是数据库对象管理和资源管理的基础。 在某种程度…

桌面备忘录,电脑桌面备忘录怎么设置

在当今快节奏的生活中&#xff0c;备忘录成为了人们工作和生活中不可或缺的工具。然而&#xff0c;随着科技的发展&#xff0c;纸质备忘录逐渐被电子桌面备忘录所取代。在电脑桌面设置备忘录&#xff0c;可以更加高效地管理任务和提醒事项。 电脑桌面是我们日常工作和娱乐的主…

2024年语言艺术、人文发展与教育国际会议(ICLAHDE2024)

2024年文学、历史与艺术设计国际会议(ICLHAD2024) 一、【会议简介】 2024年国际语言艺术、人文发展与教育会议&#xff08;ICLAHDE2024&#xff09;将在中国昆明举行&#xff0c;主题为“语言、人文与艺术”。ICLAHDE汇集了来自世界各地语言艺术、人类发展和教育领域的学者、工…

UE5C++学习(二)--- 角色简单连击

本文记录一下一个简单的角色基础连招。 它的做法就是&#xff1a;我们鼠标左键连续按下&#xff0c;会有一个动画蒙太奇索引去计数&#xff0c;获取到对应的蒙太奇动画数组中指定下标的攻击蒙太奇动画&#xff0c;然后进行播放&#xff1b;在播放的过程中用StartAttack()骨骼通…

刚刚拿到某安全公司「代码审计岗位」面试题

刚刚拿到&#xff0c;某安全公司「代码审计岗位」的面试题&#xff0c;让小编瞬间感到一股紧张又兴奋的情绪涌上心头。 代码审计&#xff0c;这个在信息安全领域里举足轻重的岗位&#xff0c;它要求的不仅仅是过硬的技术实力&#xff0c;更需要对细节敏锐的洞察力和对安全漏洞…

常见的软件系统性能测试指标

常见的软件系统性能测试指标 衡量一个软件系统性能的好坏&#xff0c;在性能测试中会使用一些性能指标来进行分析和描述&#xff0c;以下是一些最常用的性能指标。 1.2.1 响应时间 请求或者某个操作从发出的时间到收到服务器响应的时间的差值就是响应时间。在性能测试中&am…

LeetCode题练习与总结:搜索插入位置

一、题目 给定一个排序数组和一个目标值&#xff0c;在数组中找到目标值&#xff0c;并返回其索引。如果目标值不存在于数组中&#xff0c;返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 二、解题思路 初始化两个指针&#xff0c;left 指向数组…

微信小程序--开启下拉刷新页面

1、下拉刷新获取数据enablePullDownRefresh 开启下拉刷新&#xff1a; enablePullDownRefreshbooleanfalse是否开启当前页面下拉刷新 案例&#xff1a; 下拉刷新&#xff0c;获取新的列表数据,其实就是进行一次新的网络请求&#xff1a; 第一步&#xff1a;在.json文件中开…

AI程序员Devin会在6个方面影响人类程序员

讲动人的故事&#xff0c;写懂人的代码 初创公司Cognition最近所发布的世界上首个AI程序员Devin&#xff0c;让人类程序员百感交集。因为Devin能自动干下面的事情&#xff1a; 自己学习不熟悉的技术&#xff1b; 端到端地自己搭建和部署应用程序&#xff1b; 自己找出并修复…