打印

灯饰驱动芯片TM1804程序

[复制链接]
1261|0
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
528618581|  楼主 | 2017-9-8 09:30 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
/******************************************************************************
//*版权信息:深圳市天微电子有限公司
//*文 件 名:TM1804-V1.0
//*当前版本:V1.0
//*MCU 型号:STC15W104
//*开发环境:Keil uVision4
//*晶震频率:33MHZ(内部时钟)      
//*完成日期:2015-07-10
//*程序功能:1.该程序可实现5片TM1804幻彩变化。
//           2.修改变量IC可修改TM1804数量。
//*免责声明:1.此程序为TM1804驱动LED点亮演示程序,仅作参考之用。
//           2.如有直接使用本例程程序造成经济损失的,本公司不承担任何责任。            
//  如果需要其他芯片资料或需要购买芯片,QQ528618581
/*******************************************************************************/
#include <reg52.h>                            //MCU头文件
#include "intrins.h"                            //包含nop指令头文件

#define nop  _nop_();   
                   //宏定义
/********************************定义控制端口***********************************/
sbit DO=P3^3;                                    //定义信号输出DO
/**********************************定义变量*************************************/
unsigned int IC=5;                          //控制TM1804个数
unsigned int LED_PX;                        //像素点数
unsigned char PWM=255;                      //TM1804灰度数据
unsigned char Rda,Gda,Bda;                  //R、G、B灰度数据
unsigned char bdata LED_data;               //可位操作的数据发送暂存变量声明
sbit bit0=LED_data^0;                            //被发送的数据各位定义
sbit bit1=LED_data^1;
sbit bit2=LED_data^2;
sbit bit3=LED_data^3;
sbit bit4=LED_data^4;
sbit bit5=LED_data^5;
sbit bit6=LED_data^6;
sbit bit7=LED_data^7;
bit flag=0;                                 //定义一个标志位

/**********************************延时函数*************************************/
void delay(unsigned int n)                  //n=1,延时500us
{
  unsigned int i;
  while(n--)
    for(i=0;i<860;i++);
}

/********************发送0码函数,高电平400ns,周期1.25us************************/
void send_data_0()   
{
         DO=1;
         nop;nop;nop;nop;nop;
         nop;nop;nop;nop;nop;          
         DO=0;
         nop;nop;nop;nop;nop;nop;nop;
         nop;nop;nop;nop;nop;nop;nop;
}

/*******************发送1码函数,高电平800ns,周期1.25us*************************/
void send_data_1()   
{
         DO=1;
         nop;nop;nop;nop;nop;nop;
         nop;nop;nop;nop;nop;
         nop;nop;nop;nop;nop;nop;
         nop;nop;nop;nop;nop;
         DO=0;   
}

/***********************发送1个字节数据,高位先发*******************************/
void send_data(unsigned char DATA)               
{
        LED_data=DATA;                          
        if(bit7)        send_data_1();        else send_data_0();
        if(bit6)        send_data_1();        else send_data_0();
        if(bit5)        send_data_1();        else send_data_0();
        if(bit4)        send_data_1();        else send_data_0();
        if(bit3)        send_data_1();  else send_data_0();
        if(bit2)        send_data_1();  else send_data_0();
        if(bit1)        send_data_1();  else send_data_0();
        if(bit0)        send_data_1();        else send_data_0();
}
/******************************发送1帧数据*************************************/
void send_px()
{
        unsigned int i;
        for(i=0;i<LED_PX;i++)
        {
                send_data(Rda);             //发送R灰度数据
                send_data(Gda);             //发送G灰度数据
                send_data(Bda);             //发送B灰度数据
        }
}
/*===============================主函数=======================================*/
void main()
{
        unsigned char i;
        LED_PX=IC;                          //像素点数等于TM1804个数
        Rda=Gda=Bda=0;                      //R、G、B灰度数据复位清零
        while(1)
        {
                for(i=0;i<PWM;i++)          //红色渐亮  
                {
                        Rda=i;              //灰度计算
                        send_px();          //发送灰度数据
                        delay(50);          //复位延时
                }
                flag=1;                     //标志位置位
                while(flag)                 //标志位置位后循环函数
                {
                        for(i=0;i<PWM;i++)  //红色渐灭,绿色渐亮
                        {
                                Gda=i;
                                Rda=PWM-i;  //灰度计算
                                send_px();  //发送灰度数据
                                delay(50);  //复位延时
                        }
                        for(i=0;i<PWM;i++)  //绿色渐灭,蓝色渐亮
                        {
                                Bda=i;           
                                Gda=PWM-i;  //灰度计算
                                send_px();  //发送灰度数据
                                delay(50);  //复位延时
                        }
                        for(i=0;i<PWM;i++)  //蓝色渐灭,红色渐亮
                        {
                                Rda=i;
                                Bda=PWM-i;  //灰度计算
                                send_px();  //发送灰度数据
                                delay(50);  //复位延时
                        }
                }
        }
}
/*================================结束==========================================*/

相关帖子

发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

10

主题

376

帖子

5

粉丝