stm8s103 + TM1812做的自行车轮POV【原理图+取模教程】

发布时间:2012-02-7 阅读量:5601 来源: 我爱方案网 作者:

中心议题:
    *  stm8s103 + TM1812做的自行车轮POV


实物图如下,设计很不完善,很多失误,所以板子做出来一方面尺寸有问题,另外飞了N条线。





下面这个是应该达到的效果




 


下面这个是原理图:






用stm8s的高速IO的时候一定要注意上拉。

下面这个是取模软件:
风火轮全彩取模0.1版
http://www.52solution.com/data/datainfo/id/6154

 


下面是一个取模的范例:

% test_led_wheel
% for your reference

ri    = 0.1;

div_p = 128;
% div_p = 256;

div_r = 24;
% div_r = 36;

bit   = 4;

% read RGB from img
img_w = size(img, 2);
img_h = size(img, 1);
img_cx = round(img_w / 2 - 1);
img_cy = round(img_h / 2 - 1);
img_r  = min(img_cx, img_cy);


figure;
  hold on;
  axis equal;
  whitebg('k');
  xlim([-1.1, 1.1]);
  ylim([-1.1, 1.1]);

for i=1:div_p
%     plot([ri*cos(2*pi*i/div_p), cos(2*pi*i/div_p)], ...
%          [ri*sin(2*pi*i/div_p), sin(2*pi*i/div_p)]);
    for j=1:div_r
        pr = ((1-ri)/(div_r-1)*(j-1)+ri);
        px1 = cos(2*pi*(i-1)/div_p);
        px2 = cos(2*pi*(i)/div_p);
        py1 = sin(2*pi*(i-1)/div_p);
        py2 = sin(2*pi*(i)/div_p);
%         pc  = [i/div_p,j/div_r,(2-i/div_p-j/div_r)/2];
        ix = min(round(img_cx + img_r*px1*pr)+1, img_w);
        iy = min(round(img_cy + img_r*py1*pr)+1, img_h);
        icr = img(iy, ix, 1);
        icg = img(iy, ix, 2);
        icb = img(iy, ix, 3);
        pc = single([icr, icg, icb]/2^(8-bit)) * 2^(8-bit) / 256;

        plot( pr * px1, -pr * py1,  '.', ...
              'MarkerEdgeColor', pc );
    end;
end;

% byte = div_r * div_p * bit / 8
% dw   = 0.7; % m
% v    = 40;  % km/h
% n    = v/3.6/dw/pi % rps
% dt   = 1/n/div_p * 1000 % ms

效果图:



 


程序解读:

运行程序之前,需要先用matlab导入一张图像,将其点阵数据保存成变量img。
导入可以用imtool命令打开图像工具箱然后导入,也可以在matlab主菜单中import data那里



开头,

ri    = 0.1;
指定环内径比例(按外径ro=1,比如外径330mm那么内径330×0.1=33mm)

div_p = 128;
是设定自行车轮转一周要刷新的次数,或者说圆周分辨率。

div_r = 24;
是半径上面布置的LED数量。或者说半径分辨率。


bit   = 4;
是每个点的数据位数。bit有效取值:1~8

img_w = size(img, 2);
img_h = size(img, 1);
img_cx = round(img_w / 2 - 1);
img_cy = round(img_h / 2 - 1);
img_r  = min(img_cx, img_cy);
获得图像的宽、高、中心坐标、有效半径

两个循环里面,
        pr = ((1-ri)/(div_r-1)*(j-1)+ri);
        px1 = cos(2*pi*(i-1)/div_p);
        px2 = cos(2*pi*(i)/div_p);
        py1 = sin(2*pi*(i-1)/div_p);
        py2 = sin(2*pi*(i)/div_p);
将圆坐标转换成平面直角坐标


        ix = min(round(img_cx + img_r*px1*pr)+1, img_w);
        iy = min(round(img_cy + img_r*py1*pr)+1, img_h);
取对应点图上的坐标


        icr = img(iy, ix, 1);
        icg = img(iy, ix, 2);
        icb = img(iy, ix, 3);
取图片对应点的颜色,r、g、b分量

        pc = single([icr, icg, icb]/2^(8-bit)) * 2^(8-bit) / 256;
转换成matlab的颜色空间(r、g、b都在0~1之间)

plot画图

如果有网友想得到灰色图像,那么

在进入循环之前加上
img = rgb2gray(img);

然后把
        icr = img(iy, ix, 1);
        icg = img(iy, ix, 2);
        icb = img(iy, ix, 3);
        pc = single([icr, icg, icb]/2^(8-bit)) * 2^(8-bit) / 256;
改成
        ic = img(iy, ix, 1);
        pc = single([ic, ic, ic]/2^(8-bit)) * 2^(8-bit) / 256;
就行了
相关资讯
赋能新质生产力!WAIE2025深圳落幕,千项智造成果引3万专业观众瞩目

燃情落幕!7月30日至8月1日,为期三天的WAIE2025(第六届)全数会智能工业展及大会在深圳福田会展中心1号馆圆满收官。本届展会以“聚焦数字经济,赋能智能工业发展”为主题,成功打造了一场汇聚全球前沿技术与产业智慧的创新盛宴。现场不仅吸引了30000余人次专业观众亲临探索,线上直播观看更突破10万+人次,数百家行业领军企业携千余项创新成果震撼亮相,共同擘画了智能工业发展的蓬勃图景。

大立光7月营收创年内新高 高端镜头占比提升驱动旺季行情

光学镜头龙头大立光(3008.TW)公布最新财报显示,2023年7月合并营收达54.13亿元新台币,较6月大幅增长31%,同比微降0.1%,创下本年度单月营收峰值。累计前7个月总营收316.65亿元新台币,较去年同期增长14%,反映产业链复苏态势。

电视面板8月价格走势分化 中小尺寸止跌大尺寸跌幅收窄​

根据集邦科技(TrendForce)8月5日发布的最新面板价格数据,持续下跌近半年的电视面板市场在8月上旬迎来关键转折点。数据显示:32英寸、43英寸及50英寸中小尺寸电视面板价格在本月上旬结束连续6个月的跌势,正式止跌回稳!而大尺寸面板(55英寸、65英寸、75英寸)虽然延续跌势,但跌幅已明显收敛至约1美元。

鸿海7月营收创新高,AI与消费电子驱动同比增长7.25%

鸿海精密工业股份有限公司(Hon Hai Precision Industry Co., Ltd.)于8月5日正式发布2024年7月财务数据。数据显示,当月合并营业收入为6138.6亿元新台币,相比6月实现了13.6%的月度提升,较2023年同期增长7.25%,创下历年7月的最高纪录。这一强劲增长主要受到人工智能(AI)领域相关产品的持续需求驱动,同时电脑终端设备与消费智能产品的市场热度同步上升,推动整体业绩超预期发展。管理层预计,随着运营环境优化,第三季度业绩将超越第二季度表现。

全球首创"一脑多态"人形机器人合肥亮相,破解工业柔性制造难题

8月5日,合肥优艾智合机器人与西安交通大学具身智能研究院联合发布全球首创"一脑多态"架构人形机器人凌枢(LingShu)。作为具身智能领域的突破性产品,该机器人在跨场景集群协同作业领域实现技术革新,标志着工业场景智能化应用进入新阶段。