单片机论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 7159|回复: 15
收起左侧

WS2811灯光程序 单片机22路全彩控制器

  [复制链接]
wanli 发表于 2017-3-14 10:38 | 显示全部楼层 |阅读模式
WS2811芯片灯光控制程序,51单片机22路全彩控制器.

源程序:
  1. /******************************************************************************
  2. //*版权信息:深圳市天微电子有限公司
  3. //*文 件 名:TM1812-V1.0
  4. //*当前版本:V1.0
  5. //*MCU 型号:STC15W104
  6. //*开发环境:Keil uVision4
  7. //*晶震频率:33MHZ(内部时钟)      
  8. //*完成日期:07-10
  9. //*程序功能:1.该程序可实现2片TM1812幻彩变化。
  10. //           2.修改变量IC可修改TM1812数量。
  11. //*免责声明:1.此程序为TM1812驱动LED点亮演示程序,仅作参考之用。
  12. //           2.如有直接使用本例程程序造成经济损失的,本公司不承担任何责任。            
  13. /*******************************************************************************/
  14. #include <reg52.h>                            //MCU头文件
  15. #include "intrins.h"                            //包含nop指令头文件

  16. #define nop  _nop_();   
  17.                    //宏定义
  18. /********************************定义控制端口***********************************/
  19. sbit DO=P3^3;                                    //定义信号输出DO

  20. /**********************************定义变量*************************************/
  21. unsigned int IC=2;                          //控制TM1812个数
  22. unsigned int LED_PX;                        //像素点数
  23. unsigned char PWM=255;                      //TM1812灰度数据
  24. unsigned char Rda,Gda,Bda;                  //R、G、B灰度数据
  25. unsigned char bdata LED_data;               //可位操作的数据发送暂存变量声明
  26. sbit bit0=LED_data^0;                            //被发送的数据各位定义
  27. sbit bit1=LED_data^1;
  28. sbit bit2=LED_data^2;
  29. sbit bit3=LED_data^3;
  30. sbit bit4=LED_data^4;
  31. sbit bit5=LED_data^5;
  32. sbit bit6=LED_data^6;
  33. sbit bit7=LED_data^7;
  34. bit flag=0;                                 //定义一个标志位

  35. /**********************************延时函数*************************************/
  36. void delay(unsigned int n)                  //n=1,延时500us
  37. {
  38.         unsigned int i;
  39.         while(n--)
  40.                 for(i=0;i<860;i++);
  41. }

  42. /********************发送0码函数,高电平400ns,周期1.25us************************/
  43. void send_data_0()   
  44. {
  45.          DO=1;
  46.          nop;nop;nop;nop;nop;
  47.          nop;nop;nop;nop;nop;           
  48.          DO=0;
  49.          nop;nop;nop;nop;nop;nop;nop;
  50.          nop;nop;nop;nop;nop;nop;nop;
  51. }

  52. /*******************发送1码函数,高电平800ns,周期1.25us*************************/
  53. void send_data_1()   
  54. {
  55.          DO=1;
  56.          nop;nop;nop;nop;nop;nop;
  57.          nop;nop;nop;nop;nop;
  58.          nop;nop;nop;nop;nop;nop;
  59.          nop;nop;nop;nop;nop;
  60.          DO=0;   
  61. }

  62. /***********************发送1个字节数据,高位先发*******************************/
  63. void send_data(unsigned char DATA)               
  64. {
  65.         LED_data=DATA;                          
  66.         if(bit7)  send_data_1();  else send_data_0();
  67.         if(bit6)  send_data_1();  else send_data_0();
  68.         if(bit5)  send_data_1();  else send_data_0();
  69.         if(bit4)  send_data_1();  else send_data_0();
  70.         if(bit3)  send_data_1();  else send_data_0();
  71.         if(bit2)  send_data_1();  else send_data_0();
  72.         if(bit1)  send_data_1();  else send_data_0();
  73.         if(bit0)  send_data_1();  else send_data_0();
  74. }
  75. /******************************发送1帧数据*************************************/
  76. void send_px()
  77. {
  78.         unsigned int i;
  79.         for(i=0;i<LED_PX;i++)
  80.         {
  81.                 send_data(Rda);             //发送R灰度数据
  82.                 send_data(Gda);             //发送G灰度数据
  83.                 send_data(Bda);             //发送B灰度数据
  84.         }
  85. }
  86. /*===============================主函数=======================================*/
  87. void main()
  88. {
  89.         unsigned char i;
  90.         LED_PX=3*IC;                        //1个TM1812等于4个像素
  91.         Rda=Gda=Bda=0;                      //R、G、B灰度数据复位清零
  92.         while(1)
  93.         {
  94.                 for(i=0;i<PWM;i++)          //红色渐亮  
  95.                 {
  96.                         Rda=i;              //灰度计算
  97.                         send_px();          //发送灰度数据
  98.                         delay(50);          //复位延时
  99.                 }
  100.                 flag=1;                     //标志位置位
  101.                 while(flag)                 //标志位置位后循环函数
  102.                 {
  103.                         for(i=0;i<PWM;i++)  //红色渐灭,绿色渐亮
  104.                         {
  105.                                 Gda=i;
  106.                                 Rda=PWM-i;  //灰度计算
  107.                                 send_px();  //发送灰度数据
  108.                                 delay(50);  //复位延时
  109.                         }
  110.                         for(i=0;i<PWM;i++)  //绿色渐灭,蓝色渐亮
  111.                         {
  112.                                 Bda=i;           
  113.                                 Gda=PWM-i;  //灰度计算
  114.                                 send_px();  //发送灰度数据
  115.                                 delay(50);  //复位延时
  116.                         }
  117.                         for(i=0;i<PWM;i++)  //蓝色渐灭,红色渐亮
  118.                         {
  119.                                 

  120. …………余下代码请下载附件…………
复制代码
0.png
完整源码下载:
TM1812.rar (1.38 KB, 下载次数: 168)

评分

参与人数 2黑币 +10 收起 理由
江南云者 + 5 很给力!
colerwei + 5 很给力!

查看全部评分

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|单片机论坛 |51Hei单片机16群 联系QQ:125739409;技术交流QQ群7344883

Powered by 单片机教程网

快速回复 返回顶部 返回列表