SOGO論壇

標題: MATLAB 創建跑馬燈 [列印本頁]

作者: if8051    時間: 2013-12-22 09:33:49     標題: MATLAB 創建跑馬燈

MATLAB 超強功能!數學演算軟體  2D  3D  畫圖,自動控制  通訊  建模模擬,各式工程,舉凡財經研究,
DSP 開發,都需要 MATLAB,學術上用途很廣,現在展示如何設計 跑馬燈 。
  1. function dotmatrix
  2. % 跑馬燈
  3. % 圖形窗口,座標軸準備
  4. hfig=figure('position',[300   355   477   325],'color','k','name','dotmatrix','menubar','none');  % figure背景顏色
  5. axis off ;axis equal
  6. [X Y]=meshgrid(linspace(1,16,128));
  7. h=zeros(size(X));        % 存放所有「點」的 token
  8. str='熱烈歡迎 您 大駕光臨 SOGO 論壇 電子電機暨資訊工程館!';   %%%%【將此處修改成你要顯示的文字】
  9. DATA=[];
  10. for i=1:length(str)      % 調用字模提取函數文件,生成點陣數據
  11.     temp=getwordmatrix(str(i));
  12.     DATA=[DATA flipud(temp)];
  13. end
  14. DATA=[zeros(16,60) DATA zeros(16,60)];        %% 微調顯示效果,讓文字從右出現
  15. for i=1:16               % 創建點陣
  16.     for j=1:64
  17.         h(i,j)=line(X(i,j),Y(i,j),'marker','s','markersize',3,'markerfacecolor','none');
  18.             set(h(i,j),'buttondownfcn','buttondown','markeredgecolor','none');
  19.     end
  20. end

  21. % while ishandle(hfig)   % 循環改變點陣
  22. %    Z=DATA(:,1:64);
  23. %     for i=1:16
  24. %     for j=1:64
  25. %         if Z(i,j)==1
  26. %         set(h(i,j),'markerfacecolor','g');
  27. %         else         
  28. %         set(h(i,j),'markerfacecolor','none');
  29. %         end
  30. %     end
  31. %     end
  32. %  pause(1/24);
  33. %  DATA=DATA(:,[2:end 1]);
  34. %  end
  35. %% 循環顯示

  36. numFrames=0;
  37. while numFrames<(size(DATA,2)-64)/2
  38. % while ishandle(hfig)   % 循環改變點陣
  39.    Z=DATA(:,1:64);
  40.     for i=1:16
  41.     for j=1:64
  42.         if Z(i,j)==1
  43.         set(h(i,j),'markerfacecolor','g');  %%%% 更改文字顏色。'g'為綠色
  44.         else         
  45.         set(h(i,j),'markerfacecolor','none');
  46.         end
  47.     end
  48.     end
  49.     pause(.02);
  50.     DATA=DATA(:,[3:end 1:2]);
  51.     numFrames=numFrames+1;  
  52.     frames(numFrames)=getframe;
  53. end

  54. %% 寫文件
  55. animated(1,1,1,numFrames) = 0;
  56. for k=1:numFrames
  57.    if k == 1
  58.       [ animated cmap] = rgb2ind(frames(k).cdata, 256, 'nodither');
  59.    else
  60.       animated(:,:,1,k) =rgb2ind(frames(k).cdata, cmap, 'nodither');
  61.    end     
  62. end

  63. filename = 'welcome.gif';
  64. imwrite(animated, cmap, filename, 'DelayTime', .2, 'LoopCount', inf);
  65. web(filename)

  66. end

  67. %% 下面這個回調函數可以無視掉~~
  68. function buttondown      % 按下回調函數
  69. set(gcbo,'markerfacecolor',rand(1,3));
  70. end
複製代碼



附件: welcome.gif (2013-12-22 09:33:30, 412.33 KB) / 下載次數 14
https://oursogo.com/forum.php?mod=attachment&aid=NzM1OTE5NHw2N2ZkNTcwZXwxNzMyMjc0MzkzfDB8MA%3D%3D




歡迎光臨 SOGO論壇 (https://oursogo.com/) Powered by OURSOGO.COM