h=figure;
set(h,'menu','none','numbertitle','off','name','stars',...
'color',[0 0 0]);%设置figure窗体属性
% set(h,'unit','normalized','position',[0.1 0.1 0.8 0.8]);%会产生整体移动的问题
set(h,'position',[20 50 1280 700]); %比较合适
%固定坐标轴
ax=axes;
set(ax,'position',[0 0 1 1]);
axis off;
% set(gca,'position',[0 0 1 1]);
%添加文本
text('position',[0.4 0.9],'string','满天都是小星星','color','g','fontsize',20);
text(0.85,0.1,'@LanTianLuoBo','fontsize',14,'color','g');
num=20;
hp=ones(num,1);
for i=1:num
hp(i)=line('xdata',rand,'ydata',rand); %产生星星原始位置
end
while ishandle(h)
for j=1:num
xdata=get(hp(j),'xdata')+(rand*2-1)*0.001; %
ydata=get(hp(j),'ydata')+(rand*2-1)*0.001; %实现位置颤动
set(hp(j),'xdata',xdata,'ydata',ydata);
set(hp(j),'marker','p'); %线型号
set(hp(j),'markersize',15+round(rand*20));%大小变化
set(hp(j),'MarkerFaceColor',[0 rand 0]);%颜色变化
end
pause(0.1);
end
%对该程序做以下有益的思考,首先是随机函数巧妙的运用,
%line函数可以只是一个点x一个数据y一个数据,
%用rand函数使线条markersize以及颜色随机变化
%使点坐较大幅度运动rand每一次都重新生成,若使点颤动,
%第一次使用rand产生随机数,使其成为点颤动中心,用get(hp(i),'xdata')获取改值,
%然后加上(rand*2-1)*0.001,回产生颤动效果
%关于星星整体移动的问题,刚开始思考是rand设置不合理,但发现不是
%若用归一化的窗口
set(h,'menu','none','numbertitle','off','name','stars',...
'color',[0 0 0]);%设置figure窗体属性
% set(h,'unit','normalized','position',[0.1 0.1 0.8 0.8]);%会产生整体移动的问题
set(h,'position',[20 50 1280 700]); %比较合适
%固定坐标轴
ax=axes;
set(ax,'position',[0 0 1 1]);
axis off;
% set(gca,'position',[0 0 1 1]);
%添加文本
text('position',[0.4 0.9],'string','满天都是小星星','color','g','fontsize',20);
text(0.85,0.1,'@LanTianLuoBo','fontsize',14,'color','g');
num=20;
hp=ones(num,1);
for i=1:num
hp(i)=line('xdata',rand,'ydata',rand); %产生星星原始位置
end
while ishandle(h)
for j=1:num
xdata=get(hp(j),'xdata')+(rand*2-1)*0.001; %
ydata=get(hp(j),'ydata')+(rand*2-1)*0.001; %实现位置颤动
set(hp(j),'xdata',xdata,'ydata',ydata);
set(hp(j),'marker','p'); %线型号
set(hp(j),'markersize',15+round(rand*20));%大小变化
set(hp(j),'MarkerFaceColor',[0 rand 0]);%颜色变化
end
pause(0.1);
end
%对该程序做以下有益的思考,首先是随机函数巧妙的运用,
%line函数可以只是一个点x一个数据y一个数据,
%用rand函数使线条markersize以及颜色随机变化
%使点坐较大幅度运动rand每一次都重新生成,若使点颤动,
%第一次使用rand产生随机数,使其成为点颤动中心,用get(hp(i),'xdata')获取改值,
%然后加上(rand*2-1)*0.001,回产生颤动效果
%关于星星整体移动的问题,刚开始思考是rand设置不合理,但发现不是
%若用归一化的窗口