发一个单片机入门小玩意,自己焊的点阵屏
znnwe12012/09/18软件综合 IP:湖北
这是单片机入门时做的个小玩意,本来想做16*32的点阵的后来因为还差一部分8050只好压缩为16*16的了[s:116]上图
psb.jpg
psb1.jpg
psb2.jpg
psb3.jpg
psb4.jpg
psb5.jpg
psb6.jpg
是用STC12C5A60S2单片机加74hc154和74hc595做的很简陋献丑了
上C51源码

//行扫1#74hc154芯片对应数据输入口:P0^0->[s:9]0^3数据输入控制口[s:7]0^4低电平有效;行扫输出为互斥低电平输出;
//列扫1#74hc595芯片对应数据输入口:P0^5移位寄存器时钟信号;P0^6存储寄存器数据更新时钟;P0^7数据输出使能,低电平时输出有效;
//P2^0串行数据输入
#include<reg52.h>//包函头文件
#include<intrins.h>//包函_nop_延时函数的头文件
#define uchar unsigned char//宏定义
#define uint unsigned int//宏定义
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////
uchar ZMHCQ[]=
{
//16X16点阵显示缓冲区
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,    
};
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////
uchar code ZM000[]=
{
  //源文件 / 文字: 祝
  0x00,0x00,0x20,0x00,0x11,0xF8,0x01,0x08,
  0x79,0x08,0x09,0x08,0x11,0x08,0x11,0xF8,
  0x38,0x90,0x54,0x90,0x10,0x90,0x10,0x90,
  0x11,0x14,0x11,0x14,0x12,0x0C,0x00,0x00,
};
uchar code ZM001[]=
{
  //源文件 / 文字: 荣
  0x00,0x00,0x08,0x20,0x7F,0xFC,0x08,0x20,
  0x00,0x00,0x7F,0xFC,0x40,0x04,0x01,0x00,
  0x01,0x00,0x7F,0xFC,0x03,0x80,0x05,0x40,
  0x19,0x30,0x61,0x0C,0x01,0x00,0x00,0x00,
};
////////////////////////////////////////////////////////////////////////////////
sbit HC154_A=P0^0;//HC154数据输入口
sbit HC154_B=P0^1;//HC154数据输入口
sbit HC154_C=P0^2;//HC154数据输入口
sbit HC154_D=P0^3;//HC154数据输入口
sbit G1=P0^4;//HC154使能端控制
sbit SH=P0^5;//HC595移位控制
sbit ST=P0^6;//HC595锁存更新显示
sbit OE=P0^7;//HC595使能端控制
sbit DS=P2^0;//HC595串行数据输入
////////////////////////////////////////////////////////////////////////////////
void chushihua()       //硬件初始化
{
     OE=1;   //关闭HC595输出
     G1=1;   //关闭HC154输出
}
////////////////////////////////////////////////////////////////////////////////
void delay(uint ms)//延时子程序
{
    uint x,y;
    for(x=ms;x>0;x--)
        for(y=0;y<240;y++);
}
////////////////////////////////////////////////////////////////////////////////
//低位先入
void sendbyte(uchar Rdate)//HC595串行输入一个字节
{
    uint a;
    uchar date=Rdate;
    for(a=0;a<8;a++)
    {
        SH=0;
        if(date&0x01)//先将最低位移入
        {
        DS=1;
        SH=1;
        }
        else
        {
        DS=0;
        SH=1;
        }
        date=date>>1;//输入的字节位右移
    }
}
////////////////////////////////////////////////////////////////////////////////
void HC595_GX()     //HC595锁存数据更新并输出
{
    ST=0;
    _nop_();
    ST=1;    //HC595锁存数据更新
    _nop_();
    OE=0;    //HC595输出    
}
////////////////////////////////////////////////////////////////////////////////
void HC154_HS(uint x)//X行低电平输出
{
    G1=0;
    switch(x)
   {
    case 1:
      HC154_A=0;
      HC154_B=0;
      HC154_C=0;
      HC154_D=0;
      break;
     case 2:
      HC154_A=1;
      HC154_B=0;
      HC154_C=0;
      HC154_D=0;
      break;
     case 3:
      HC154_A=0;
      HC154_B=1;
      HC154_C=0;
      HC154_D=0;
      break;
     case 4:
      HC154_A=1;
      HC154_B=1;
      HC154_C=0;
      HC154_D=0;
      break;
     case 5:
      HC154_A=0;
      HC154_B=0;
      HC154_C=1;
      HC154_D=0;
      break;
     case 6:
      HC154_A=1;
      HC154_B=0;
      HC154_C=1;
      HC154_D=0;
      break;
     case 7:
      HC154_A=0;
      HC154_B=1;
      HC154_C=1;
      HC154_D=0;
      break;
     case 8:
      HC154_A=1;
      HC154_B=1;
      HC154_C=1;
      HC154_D=0;
      break;
     case 9:
      HC154_A=0;
      HC154_B=0;
      HC154_C=0;
      HC154_D=1;
      break;
     case 10:
      HC154_A=1;
      HC154_B=0;
      HC154_C=0;
      HC154_D=1;
      break;
     case 11:
      HC154_A=0;
      HC154_B=1;
      HC154_C=0;
      HC154_D=1;
      break;
     case 12:
      HC154_A=1;
      HC154_B=1;
      HC154_C=0;
      HC154_D=1;
      break;
     case 13:
      HC154_A=0;
      HC154_B=0;
      HC154_C=1;
      HC154_D=1;
      break;
     case 14:
      HC154_A=1;
      HC154_B=0;
      HC154_C=1;
      HC154_D=1;
      break;
     case 15:
      HC154_A=0;
      HC154_B=1;
      HC154_C=1;
      HC154_D=1;
      break;
     case 16:
      HC154_A=1;
      HC154_B=1;
      HC154_C=1;
      HC154_D=1;
      break;
    default:
      break;
  }
}
////////////////////////////////////////////////////////////////////////////////
void OUT16x16()//点阵屏输出16x16点阵字模缓冲区数据
{
     uint y;//行扫数据控制
     uint x_H;//列高位数据控制
     uint x_L;//列低位数据控制
     for(y=1,x_H=0,x_L=1;y<=16;y++)
     {
       sendbyte(ZMHCQ[x_L]);
       sendbyte(ZMHCQ[x_H]);
       HC595_GX();
       HC154_HS(y);
       x_H+=2;
       x_L+=2;
       delay(1);  
     }    
}
////////////////////////////////////////////////////////////////////////////////
void ZMHCQ_GX(uchar code ZM[31])//以静态方式向字模缓冲区写入一个16x16点阵字模数据
{
uint x;
for(x=0;x<32;x++)
{
  ZMHCQ[x]=ZM[x];                
}    
}
////////////////////////////////////////////////////////////////////////////////
void ZMHCQ_YY()//字模缓冲区数据按行右移一位
{
uint x_H,x_L,y;
uchar date;
for(y=1,x_H=0,x_L=1;y<=16;y++)
{
  ZMHCQ[x_L]=ZMHCQ[x_L]>>1;//将x_L字节的低位移出空出高位
  date=ZMHCQ[x_H];
  if(date&0x01)//将最x_H字节的低位移入x_L字节的高位
        {
         ZMHCQ[x_L]=ZMHCQ[x_L]|0x80;        
        }
        else
        {        
         ZMHCQ[x_L]=ZMHCQ[x_L]&0x7F;
        }
   ZMHCQ[x_H]=ZMHCQ[x_H]>>1;//x_H字节右移一位
   x_H+=2;
   x_L+=2;                                
}    
}
////////////////////////////////////////////////////////////////////////////////
uint byte_b(uchar Rdate,uint x)//函数返回date字节数据倒数第x位的值
{
  uchar date;
  date=Rdate;
  date=date>>(x-1);  
if(date&0x01) {return 1;}else {return 0;}    
}
////////////////////////////////////////////////////////////////////////////////
void ZMHCQ_GX_YY(uchar code ZM[31],uint s)//以右移方式向字模缓冲区写入数据s为移动速度
{
  uint x,y,i,j;
  for(x=1;x<=8;x++)
  {
   ZMHCQ_YY();                
   for(i=1,y=1,j=0;i<=16;i++)
   {                    
   if(byte_b(ZM[y],x))
   {
    ZMHCQ[j]=ZMHCQ[j]|0x80;                  
   }
   else
   {
    ZMHCQ[j]=ZMHCQ[j]&0x7F;  
   }
   y+=2;
   j+=2;
   OUT16x16();
   delay(s);              
   }                
  }
  for(x=1;x<=8;x++)
  {
   ZMHCQ_YY();                
   for(i=1,y=0,j=0;i<=16;i++)
   {                    
   if(byte_b(ZM[y],x))
   {
    ZMHCQ[j]=ZMHCQ[j]|0x80;                  
   }
   else
   {
    ZMHCQ[j]=ZMHCQ[j]&0x7F;  
   }
   y+=2;
   j+=2;
   OUT16x16();
   delay(s);              
   }                
  }    
}
////////////////////////////////////////////////////////////////////////////////
void main()       //主函数
{
   uint x,y;
   chushihua();
   while(1)
    {
     ///////////////////////////////////////////////////////////////////////////      
     ZMHCQ_GX(ZM000);
     for(y=0;y<16;y++)
     {      
     for(x=0;x<20;x++)
     {
       OUT16x16();
     }
     ZMHCQ_YY();
     }
     ///////////////////////////////////////////////////////////////////////////
     ZMHCQ_GX(ZM001);
     for(y=0;y<16;y++)
     {
     for(x=0;x<20;x++)
     {
       OUT16x16();
     }
     ZMHCQ_YY();
     }
     ///////////////////////////////////////////////////////////////////////////
     ZMHCQ_GX_YY(ZM000,2);
     ZMHCQ_GX_YY(ZM001,2);
    }  
    
}
+10  科创币    科学人    2012/09/19
来自:计算机科学 / 软件综合
6
已屏蔽 原因:{{ notice.reason }}已屏蔽
{{notice.noticeContent}}
~~空空如也
znnwe1 作者
12年4个月前 IP:未同步
452799
做玩这东西本人焊功大有精进[s:243]
引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论
znnwe1作者
12年4个月前 IP:未同步
452801
其实我想问,怎么能让账号10天后不被冻结呢?我前面申请的一个号就被冻结了,求帮助[s:241]
+15
科创币
飞面教徒
2012-09-18
发这种帖子就不会被冻结啦
+10
科创币
阿飘先生
2012-09-18
莫名有种加分的赶脚·········
+10
科创币
听我说瞎话
2012-09-18
暴徒正解!
引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论
znnwe1作者
12年4个月前 IP:未同步
452820
做完后才发觉根本不需要8050,8550对管来驱动点阵74hc154和74hc595的驱动能力还是很牛逼的但都装起来后就实在不想再改了,接线太蛋疼了可惜了我的那4块8x8点阵,浪费了[s:309]
引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论

想参与大家的讨论?现在就 登录 或者 注册

所属专业
上级专业
同级专业
znnwe1
笔友
文章
8
回复
34
学术分
0
2012/09/16注册,6年11个月前活动
暂无简介
主体类型:个人
所属领域:无
认证方式:邮箱
IP归属地:未同步
文件下载
加载中...
{{errorInfo}}
{{downloadWarning}}
你在 {{downloadTime}} 下载过当前文件。
文件名称:{{resource.defaultFile.name}}
下载次数:{{resource.hits}}
上传用户:{{uploader.username}}
所需积分:{{costScores}},{{holdScores}}下载当前附件免费{{description}}
积分不足,去充值
文件已丢失

当前账号的附件下载数量限制如下:
时段 个数
{{f.startingTime}}点 - {{f.endTime}}点 {{f.fileCount}}
视频暂不能访问,请登录试试
仅供内部学术交流或培训使用,请先保存到本地。本内容不代表科创观点,未经原作者同意,请勿转载。
音频暂不能访问,请登录试试
支持的图片格式:jpg, jpeg, png
插入公式
评论控制
加载中...
文号:{{pid}}
投诉或举报
加载中...
{{tip}}
请选择违规类型:
{{reason.type}}

空空如也

加载中...
详情
详情
推送到专栏从专栏移除
设为匿名取消匿名
查看作者
回复
只看作者
加入收藏取消收藏
收藏
取消收藏
折叠回复
置顶取消置顶
评学术分
鼓励
设为精选取消精选
管理提醒
编辑
通过审核
评论控制
退修或删除
历史版本
违规记录
投诉或举报
加入黑名单移除黑名单
查看IP
{{format('YYYY/MM/DD HH:mm:ss', toc)}}