HC74h595 串行输出再进行串口输出(串行通信嵌套)已测试成功。

 

以下74HC595多个连接原理图、

 

          

一行发送数据完,输出寄存器一个上升沿把并行输出
sdclkLEOEsdclkLEOEsdclkLEOE
            

    

  LE=0; LE=1;  //输出寄存器一个上升沿。 


           

 

注---20201226日测试时有时会测试时间温度屏时有时某个点位会闪,没有规则的位置,改了几天的程序都不行,有时又会,后面加上电容也有时会有时不会,后面用一带有245的灯板过线对信号放大再测试没有发现有问题,打样再测试再说,增加一个245对输出信号放大。

 

 


//==============================================
//功能:用于一次性写入显示串行数据。
//参数: RowBuffer 一次数组
//参数: colour 显示颜色
//参数: ColumnLength  要写入的数据长度,以char为单位。
//参数: Dispoint_State 当前写入锁存输出1:0:不显示  1:显示
//==============================================
xdata unsigned char dispoint_buf[8][8]= {black};
xdata unsigned char dispoint_buf_back[8][8]= {black};
xdata unsigned char char_MitiArray[8]= {8,2,3,4,5,6,7,8};
xdata  char  DispointState[8]= {4,4,4,4,4,4,3,4};
xdata  char  AllWriteOneColumn[8]= {0,0,0,0,0,0,0,0};
xdata unsigned  char byte_dat[8] = {0};
char  Write_number1BiteRow0(unsigned char *number, char colour,char ColumnLength, char *Dispoint_State   ) /* 将单组数字的8个字节编码写入4个16位寄存器(MBI5026) */
{
    bit _clkSD;
    bit _sdataSD;
	  
    unsigned char a, rel =0;// 单组编码内相对偏移量
    char i,k,x,y,*dipstate;
  //  EA=0;//关闭总中断。
  //  OE=0;
	
    if(sizeof(Dispoint_State)==0&&ColumnLength<=0&&sizeof(number)==0) {
        return -1 ;
    }
    //(1).串行传数据再并线数据,可以实现在一个串行线上再实现多个并行传输出。
    for(rel=0; rel<8; rel++) {
        for( y=ColumnLength-1; y>=0; y--) {//每次写入前都要重新更新一下数组数据。
            a=*(number+y);
            byte_dat[ColumnLength-1-y] = char_encoding[ *(number+y)*8+rel ];
        }
        //(2).发送1个笔段位(含8个字),方法是串行移位好数据然后发送一个输出锁存(LE=0,LE=1输出数据,用示波器测得595只有上升沿时才会变化,与上一次电平一样时输出IO不会变化波动)

        for(i=0; i<8; i++) {
        //(3). 595一个上升上降沿分4次发送(595相同电平不会变化波动)
            for(x=0; x<4; x++) {
                LE=0;
                for(k=0; k<ColumnLength; k++) {
	                  WDT_CONTR=0x37;//看门狗清零
                    1.发使能位,原理图SD-SC-LE-OE
                    CLK =0;
                    if(colour == GRN) {
                        SD =SD  &0x80;   // 注意C51中才可以使用这种形式取信号,ST MCU不可以
                    }
                    else if(colour == RED) {
                        SD = 0;
                    }
                    else if(colour == ALL) {
                        SD = 1;
                    }
                    CLK =1;
										
                    2.锁存位,原理图SD-SC-LE-OE
                    CLK =0;
                    if(colour == GRN) {
                        SD1 = byte_dat[k] &0x80;  
                        SD =0;
                    }
                    else if(colour == RED) {
											   
                        if((int)rel==7&&(int)i==7 ) {
												    dipstate= (Dispoint_State+(ColumnLength-k-1))	;//得到对应的实参是否为0,为0时不。
													  
                            if( *dipstate ) { 
                                 if (x==2&&(--*dipstate==0)) {  _clkSD= SD =1;} //得到对应的实参是否为0,为0时不。
                                else if (x==3) _clkSD=SD=0; //退出时,如果大于0要减1;
                                else if (x==0) _clkSD=SD=0;
                                else if (x==1) _clkSD=SD=0;
                                else _clkSD=SD=0;
                            }
														
                        } else _clkSD= SD= 0;

                    }
                    CLK =1;
										
                    3.发时钟位,原理图SD-SC-LE-OE
                    CLK =0;
                    if(colour == GRN) {
                        SD =1;   
                    }
                    else if(colour == RED) {
											  _clkSD=8;
                        if (x==1)  _clkSD= SD =1; 
                        else if (x==0) _clkSD=SD=0;											
                        else if (x==2) _clkSD=SD=0;
                        else if (x==3) _clkSD=SD=0;
                   
                    }
                    else if(colour == ALL) {
                        if (x==1)  _clkSD= SD =1;       
                        else if (x==2) _clkSD=SD=0;
                        else if (x==3) _clkSD=SD=0;
                        else if (x==0) _clkSD=SD=0;
								
											

                    }
                    CLK =1;
										
                    4.发数据位,原理图SD-SC-LE-OE
                    CLK =0;
                    if(colour == GRN) {
                        SD1 = byte_dat[k] &0x80;    
                        SD =0;
                    }
                    else if(colour == RED) {
                        _sdataSD= SD= byte_dat[k] &0x80;      
                    }
                    else if(colour == ALL) {
                        SD= byte_dat[k] &0x80;
                    }
                    CLK =1;
                    if(x==3) byte_dat[k] = byte_dat[k]<<1;
                }
							//	  _nop_();
				
                LE=1;//一个上升沿更新一次串口数据,电平无变化无波动。
						//		  Delay_N10us(1);
            //    _nop_(); //这里用的595,不同芯片延时不同。

            }
            }
						
      //  _nop_();
      
    }
		// EA=1;//关闭总中断。
		return 0;
	//	*Dispoint_State=(*Dispoint_State)-1; //
		

}




//==============================================

//功能:用于一次性写入显示串行数据,
//参数: RowBuffer 一次数组
//参数: colour 显示颜色
//参数: ColumnLength  要写入的数据长度,以char为单位。
//参数: Dispoint_State 当前写入锁存输出1:如果为0时会执行写入锁存
//参数: DispointArray  显示的二维数组。
//参数: AllWriteOneColumn  如果为数组中对应为大于0时显示这个数显示,为0时不替换。
//例如: WriteMitiROwsData(char_MitiArray,RED,8,DispointState , dispoint_buf);
unsigned char Dispoint_State_temp[8]={black};
//==============================================
void  WriteMitiROwsData(unsigned char *RowBuffer, char colour,char ColumnLength, char *Dispoint_State, unsigned char DispArray[8][8] , unsigned char *ColumnWriteBlack){
 unsigned char b,(*tempP)[8],i1=0,i2=0;
 
	tempP=DispArray;
	//得到最大值。
//	len= sizeof(Dispoint_State)/sizeof(unsigned char);

	//用于重新赋值给显示状态
for(i1=0;i1<8;i1++){
	 *(Dispoint_State_temp+i1)=*(Dispoint_State+i1);
	 }


//  //用于测试
//	for(i1=0;i1<8;i1++){
//	   for(i2=0;i2<8;i2++){
//      DispArray[i1][i2]=i1;
//     }
//	 }	
	 
 //用于重写前备份数据
	   for(i2=0;i2<8;i2++){
	for(i1=0;i1<8;i1++){
	 
       dispoint_buf_back[i1][i2]=DispArray[i1][i2];
     }
	   }

  //用于重写入数据
		   for(i2=0;i2<8;i2++){
	for(i1=0;i1<8;i1++){
	 
			 if(*(ColumnWriteBlack+i1))
       DispArray[i1][i2]=*(ColumnWriteBlack+i1);
     }
	   }


	 
	 //用于写入多行数据。
	for(i1=0;i1<8;i1++){ 	
		Write_number1BiteRow0(DispArray[i1],colour, ColumnLength,Dispoint_State_temp);		//写入一维数组的数据。	
	}
	
	//用于重写后还原备份数据
	  for(i2=0;i2<8;i2++){
	for(i1=0;i1<8;i1++){
	 
       DispArray[i1][i2]=dispoint_buf_back[i1][i2];
     }
	   }
}

 


 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值