一乐电子

 找回密码
 请使用微信账号登录和注册会员

QQ登录

只需一步,快速开始

微信扫码登录

搜索
查看: 5482|回复: 10

求标准08接口的双色32*64点阵屏幕

[复制链接]
发表于 2013-5-26 16:12 | 显示全部楼层 |阅读模式
如题,已经太郁闷了,所以求标准屏吧。希望哪位有能联系一下,能发平邮最好
发表于 2013-5-26 16:20 | 显示全部楼层
你是有驱动板没屏?
回复

使用道具 举报

发表于 2013-5-26 16:24 | 显示全部楼层
这东西只要是标准的扫描方式就行 不一定要08接口   大部分只是接口顺序不一样 或者多个oe 使能什么的
回复

使用道具 举报

发表于 2013-5-26 20:50 | 显示全部楼层
我有一块双色64X32的,不知道是不是08接口,要怎么看?
回复

使用道具 举报

 楼主| 发表于 2013-5-26 21:17 | 显示全部楼层
看中音乐电平显示器,感觉挺好玩的,买了几个驱动板,告诉我直接08接口的标准屏就能用
手中有几个32*64的双色屏  可是都不是标准的08接口
最接近的一个接口方式如下
B         A
C        CP(经查 这个是clk)
D        CT(经查这个是OE)
gnd    SC(经查这个是STB)
gnd    G1
gnd    G2
gnd    R1
gnd    R2
虽然也是16个接口,但是不是标准的08屏
费劲找到以前在老沈那里购买的TF-2驱动卡,找了一天的驱动光盘
找到后,接线口飞线解决,经过调试,倒是可以用TF-2卡驱动,正常显示,细节方面是:数据极性—— 低有效;OE极性——高有效
可能跟标准的08接口不符
哪位帮忙看看程序该如何改
回复

使用道具 举报

 楼主| 发表于 2013-5-26 21:21 | 显示全部楼层
c语言的源代码吧
#include<STC12C5A60S2.H>
#define uchar unsigned char
#define uint unsigned int  
#define  channel  0x00              //设置AD通道为 P1.0
//----http://80mcu.taobao.com------------------qq:274108610-----------------------------------------------
#define ADC_POWER   (1<<7)
#define ADC_SPEEDHH (0x03<<5)
#define ADC_START   (1<<3)
#define PADCH       (1<<5)
#define ADC_FLAG    (1<<4)

sbit  SDA_R_TOP=P3^4;
sbit  SDA_R=P3^2;

sbit  SDA_G_TOP=P3^5;
sbit  SDA_G=P3^3;               


sbit  STCP=P1^7;
sbit  SHCP=P1^6;

sbit  EN=P3^6;
//---------------------------------------------------------------------
//----------------------------------------------------------------------------------------------------------------------
//放大128倍后的sin整数表(128)   
code char SIN_TAB[128] = { 0, 6, 12, 18, 24, 30, 36, 42, 48, 54, 59, 65, 70, 75, 80, 85, 89, 94, 98, 102,

105, 108, 112, 114, 117, 119, 121, 123, 124, 125, 126, 126, 126, 126, 126, 125, 124, 123, 121, 119, 117, 114, 112,

108, 105, 102, 98, 94, 89, 85, 80, 75, 70, 65, 59, 54, 48, 42, 36, 30, 24, 18, 12, 6, 0, -6, -12, -18, -24, -30,

-36, -42, -48, -54, -59, -65, -70, -75, -80, -85, -89, -94, -98, -102, -105, -108, -112, -114, -117, -119, -121,

-123, -124, -125, -126, -126, -126, -126, -126, -125, -124, -123, -121, -119, -117, -114, -112, -108, -105, -102,

-98, -94, -89, -85, -80, -75, -70, -65, -59, -54, -48, -42, -36, -30, -24, -18, -12, -6 };

//放大128倍后的cos整数表(128)
code char COS_TAB[128] = { 127, 126, 126, 125, 124, 123, 121, 119, 117, 114, 112, 108, 105, 102, 98, 94,

89, 85, 80, 75, 70, 65, 59, 54, 48, 42, 36, 30, 24, 18, 12, 6, 0, -6, -12, -18, -24, -30, -36, -42, -48, -54, -59,

-65, -70, -75, -80, -85, -89, -94, -98, -102, -105, -108, -112, -114, -117, -119, -121, -123, -124, -125, -126, -

126, -126, -126, -126, -125, -124, -123, -121, -119, -117, -114, -112, -108, -105, -102, -98, -94, -89, -85, -80,

-75, -70, -65, -59, -54, -48, -42, -36, -30, -24, -18, -12, -6, 0, 6, 12, 18, 24, 30, 36, 42, 48, 54, 59, 65, 70,

75, 80, 85, 89, 94, 98, 102, 105, 108, 112, 114, 117, 119, 121, 123, 124, 125, 126, 126 };

//采样存储序列表
code char LIST_TAB[128] = { 0, 64, 32, 96, 16, 80, 48, 112,
8, 72, 40, 104, 24, 88, 56, 120,
4, 68, 36, 100, 20, 84, 52, 116,
12, 76, 44, 108, 28, 92, 60, 124,
2, 66, 34, 98, 18, 82, 50, 114,
10, 74, 42, 106, 26, 90, 58, 122,
6, 70, 38, 102, 22, 86, 54, 118,
14, 78, 46, 110, 30, 94, 62, 126,
1, 65, 33, 97, 17, 81, 49, 113,
9, 73, 41, 105, 25, 89, 57, 121,
5, 69, 37, 101, 21, 85, 53, 117,
13, 77, 45, 109, 29, 93, 61, 125,
3, 67, 35, 99, 19, 83, 51, 115,
11, 75, 43, 107, 27, 91, 59, 123,
7, 71, 39, 103, 23, 87, 55, 119,
15, 79, 47, 111, 31, 95, 63, 127
};


uchar COUNT=15,COUNT1=0,ADC_Count=0,LINE=15,G,T;
uchar i,j,k,b,p;                 
int Temp_Real,Temp_Imag,temp;                // 中间临时变量  
uint TEMP1;   
int xdata Fft_Real[128];
int xdata Fft_Image[128];               // fft的虚部
uchar xdata LED_TAB2[16];                //记录 漂浮物 是否需要 停顿一下
uchar xdata LED_TAB[16];                //记录红色柱状
uchar xdata LED_TAB1[16];                //记录 漂浮点

void FFT()
{     //uchar x;              
    for( i=1; i<=7; i++)                            /* for(1) */
    {
        b=1;
        b <<=(i-1);                                       //碟式运算,用于计算 隔多少行计算 例如 第一极 1和2行计算,,第二级
        for( j=0; j<=b-1; j++)                              /* for (2) */
        {
            p=1;
            p <<= (7-i);            
            p = p*j;
            for( k=j; k<128; k=k+2*b)                /* for (3) 基二fft */
            {
                Temp_Real = Fft_Real[k]; Temp_Imag = Fft_Image[k]; temp = Fft_Real[k+b];
                Fft_Real[k] = Fft_Real[k] + ((Fft_Real[k+b]*COS_TAB[p])>>7) + ((Fft_Image[k+b]*SIN_TAB[p])>>7);
                Fft_Image[k] = Fft_Image[k] - ((Fft_Real[k+b]*SIN_TAB[p])>>7) + ((Fft_Image[k+b]*COS_TAB[p])>>7);
                Fft_Real[k+b] = Temp_Real - ((Fft_Real[k+b]*COS_TAB[p])>>7) - ((Fft_Image[k+b]*SIN_TAB[p])>>7);
                Fft_Image[k+b] = Temp_Imag + ((temp*SIN_TAB[p])>>7) - ((Fft_Image[k+b]*COS_TAB[p])>>7);     
                // 移位.防止溢出. 结果已经是本值的 1/64               
              Fft_Real[k] >>= 1;            
                Fft_Image[k] >>= 1;
               Fft_Real[k+b]  >>= 1;                 
                Fft_Image[k+b]  >>= 1;
                                                                              
            }     
        }
    }
//     Fft_Real[0]=Fft_Image[0]=0;          //去掉直流分量
//     Fft_Real[63]=Fft_Image[63]=0;
//    x=((((Fft_Real[1]* Fft_Real[1]))+((Fft_Image[1]*Fft_Image[1])))>>5);
    for(j=0;j<16;j++)                                             
    {                                                                              
        TEMP1=((((Fft_Real[j+1]* Fft_Real[j+1]))+((Fft_Image[j+1]*Fft_Image[j+1])))>>1);//求功率
        if(TEMP1>1)TEMP1--;
        else TEMP1=0;
        if(TEMP1>31)TEMP1=31;
        if(TEMP1>(LED_TAB[j]))LED_TAB[j]=TEMP1;   
        if(TEMP1>(LED_TAB1[j]))
        {   LED_TAB1[j]=TEMP1;
            LED_TAB2[j]=14;                        //提顿速度=12
        }
    }      
}

void Init()
{  
   
//-----------------------------------------------------------------------------------
     P1ASF = 0x02;                 //0000,0010, 将 P1.1 置成模拟口
     P1M0 = 0x01;                                //0000,0001用于A/D转换的P1.x口,先设为开漏
     P1M1 = 0x01;                                //0000,0001 P1.0先设为开漏。断开内部上拉电阻
   
     AUXR1 &=0xFB;                 //1111,1011, 令 ADRJ=0
     
     EADC=1;                       //AD中断打开
     ADC_CONTR = ADC_POWER | ADC_SPEEDHH | ADC_START | channel;
                   //1110 1001   1打开 A/D (ADC_POWER)转换电源;11速度为70周期一次;
                   //0中断标志清零;1启动adc(ADC_START);001AD通道打开(这里为P1.1);
//-----------------------------------------------------------------------------------
     //P1M0=P1M1=1;
     P2M0=0xff;
     P3M0=0xff;
     TMOD=0X12;                       
     TH0=0xb0;      //                                             
     TL0=0xb0;
     TH1=0xEE;                                                   
     TL1=0XC0;
     ET0=1;                           //定时器0 打开
     TR0=0;                              //关闭定时器
     ET1=1;
     TR1=1;
     PT1=0;
     PT0=1;
     IPH=PADCH;
     IP=PADC;                          //中断优先级
     EA=1;                            //总中断打开
}


void ADC_Finish() interrupt 5
{       ADC_CONTR &= !ADC_FLAG;
        Fft_Real[LIST_TAB[ADC_Count]]=(int)((ADC_RES)<<1)+(ADC_RESL>>1)*2;//-512; //按LIST_TAB表里的顺序,进行存储 采样值,,
//      ADC_CONTR = ADC_POWER | ADC_SPEEDHH| ADC_START | channel;    // 为了采集负电压,采用 偏置采集。电压提高到1/2 vcc,,所以要减去256
      if(ADC_Count<=127)ADC_Count++;
      else {EADC=0;TR0=0;}                                                           
}

void LED_Display() interrupt 3                     //中断一次 显示一行。。。
{         
     TH1=0xfa;                                                
     TL1=0X09;                        
        for    (G=0;G<16;G++)                          //往点阵屏填充 一行的 数据
        {   
            if(LED_TAB[G]<=LINE+16)
                SDA_R_TOP=1;
            else
                SDA_R_TOP=0;
              if(LED_TAB[G]<=LINE)
                SDA_R=1;
            else
                SDA_R=0;

            if(LED_TAB1[G]==LINE)
            {
                SDA_G_TOP=1;SDA_G=0;
            }
            else if(LED_TAB1[G]==(LINE+16))
            {   
                SDA_G_TOP=0;SDA_G=1;
            }
            else
                SDA_G=SDA_G_TOP=1;

            SHCP=1;SHCP=0;
            SHCP=1;SHCP=0;
            SHCP=1;SHCP=0;
            SDA_G_TOP=1;SDA_G=1;SDA_R_TOP=1;SDA_R=1;
            SHCP=1;SHCP=0;
        }
        EN=1;
        STCP=1;
        P2=15-LINE;
        STCP=0;
        if(LINE>0)LINE--;
        else LINE=15;
        EN=0;
  //////////////////////////
   
   if(LED_TAB[COUNT]>0)LED_TAB[COUNT]--;           //柱状递减,
     if(COUNT>0)COUNT--;
    else COUNT=15;
   if(LED_TAB[COUNT]>0)LED_TAB[COUNT]--;
    if(COUNT>0)COUNT--;
    else COUNT=15;

                                                      //漂浮物递减
//  if(LED_TAB2[COUNT1]==0)                    //判断是否需要停顿      
//  {
//           if(LED_TAB1[COUNT1]>LED_TAB[COUNT1])LED_TAB1[COUNT1]--;//大于柱状则递减(保持漂浮物在柱状之上)
//   }
//  else LED_TAB2[COUNT1]--;
//   COUNT1++;
//   if(COUNT1>=16)COUNT1=0;
   if(LED_TAB2[COUNT1]==0)
   {
           if(LED_TAB1[COUNT1]>LED_TAB[COUNT1])LED_TAB1[COUNT1]--;
   }
   else LED_TAB2[COUNT1]--;
   COUNT1++;
   if(COUNT1>=16)COUNT1=0;
}

void Ad_Control() interrupt 1                     //控制采样率
{
ADC_CONTR = ADC_POWER | ADC_SPEEDHH| ADC_START | channel;     //开始AD采集
}
  //==============================================================================================================
//    *******************                               main()                            *********************************                                          
//===============================================================================================================

void main()
{
    uchar i;
     Init();
    EN=1;
    while(1)
    {        
        ADC_Count=0;
        TR0=1;
        EADC=1;    //开启定时器中断0,,开启ADC
        while(ADC_Count<128);
        for(i=0;i<128;i++)
        {
         Fft_Image=0;
        }
        FFT();
     //FFT运算。并转换为 功率值。。。                           
        //    TR1=1;         
    }
}


附件添加了 C源代码(标准)_2.rar (42.93 KB, 下载次数: 5)
回复

使用道具 举报

 楼主| 发表于 2013-5-26 21:25 | 显示全部楼层
dadiok20 发表于 2013-5-26 16:24
这东西只要是标准的扫描方式就行 不一定要08接口   大部分只是接口顺序不一样 或者多个oe 使能什么的

非常感谢,你的这句话给我的灵感,调整的几个参数,终于能够通过驱动板点亮了
回复

使用道具 举报

 楼主| 发表于 2013-5-26 21:29 | 显示全部楼层
附上源代码,哪位帮忙看看,是否跟 数据极性—— 低有效;OE极性——高有效          冲突  
回复

使用道具 举报

发表于 2013-5-26 22:06 | 显示全部楼层
数据极性要是反了 ,显示的内容双色的板子, 就成了黄底 红字 或者绿字黑字。oe极性反了, 一般会出现暗亮的情况。
回复

使用道具 举报

发表于 2013-6-7 21:24 | 显示全部楼层
我有快  不知道你多少收
  运费实收
回复

使用道具 举报

本版积分规则

QQ|一淘宝店|手机版|商店|一乐电子 ( 粤ICP备09076165号 ) 公安备案粤公网安备 44522102000183号

GMT+8, 2025-8-7 05:32 , Processed in 0.042936 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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