標(biāo)題:
關(guān)于led點陣文字移動問題
[打印本頁]
作者:
YZYNULL
時間:
2022-12-17 19:09
標(biāo)題:
關(guān)于led點陣文字移動問題
本人做了一款led點陣32x32的,掃描方式是逐行掃描,那么在代碼實現(xiàn)靜態(tài)文字或者文字上下移沒什么難點,靜態(tài)顯示無非就是開一個顯存把文字?jǐn)?shù)據(jù)寫進顯存然后掃描就完了,上下移也就多了一步字節(jié)推擠寫一個用定時器數(shù)據(jù)推擠,推擠顯存中的數(shù)據(jù)一個字節(jié)一個字節(jié)跟可以完美實現(xiàn)上下移,到了左右移那么問題來了由于pcb設(shè)計掃描結(jié)構(gòu)為逐行掃描,上下移可以推入整個字節(jié)達到目的,左右移總不能直接移一個字節(jié)吧8個點顯然不行,所以怎么將字節(jié)左移到高位通過算法接入下一個字節(jié)的低位呢,辦法我是有的但是有點太笨了所以來請教大神們,如下代碼。typedef unsigned char u8;
typedef unsigned int u16;
sbit SDI = P6^0;
sbit CLK = P6^1;
sbit LE = P6^2;
u8 xdata Byte[4];
u8 xdata Byte_cache[4];
void Delay_ms(u16 l) //@30.000MHz 1ms
{
unsigned char i, j;
u16 h;
for(h=0;h<l;h++)
{
_nop_();
i = 32;
j = 40;
do
{
while (--j);
} while (--i);
}
}
void HC595_Init()
{
SDI = 0;
CLK = 0;
LE = 0;
}
void HC595_Write_Data(u16 op)
{
u16 i,k;
for(i=0;i<8;i++)
{
CLK=0;
SDI=op&0x80;
CLK=1;
op<<=1;
}
}
/*0000 0000 0001 */
void main()
{
u8 ii;
HC595_Init();
while(1)
{
Byte[1]=0x00;Byte[2]=0x00;Byte[3]=0x00,Byte[4]=0x01;
for(ii=0;ii<32;ii++)
{
if((Byte[1]&0x80)==128){Byte_cache[1]=0x01;} else{Byte_cache[1]=0x00;} //如果字節(jié)高位等于1那么字節(jié)緩存等于1
Byte[1]=Byte[1]+Byte_cache[2]; //下一個字節(jié)加上上一個字節(jié)的緩存
if((Byte[2]&0x80)==128){Byte_cache[2]=0x01;} else{Byte_cache[2]=0x00;}
Byte[2]=Byte[2]+Byte_cache[3];
if((Byte[3]&0x80)==128){Byte_cache[3]=0x01;} else{Byte_cache[3]=0x00;}
Byte[3]=Byte[3]+Byte_cache[4];
HC595_Write_Data(Byte[1]);
HC595_Write_Data(Byte[2]);
HC595_Write_Data(Byte[3]);
HC595_Write_Data(Byte[4]);
LE =1;
_nop_();
LE =0;
Delay_ms(100);
Byte[1]<<=1;
Byte[2]<<=1;
Byte[3]<<=1;
Byte[4]<<=1;
}
}
}
這組代碼可以實現(xiàn)字節(jié)的按位推擠這是組測試代碼跑的流水燈剛好達到了的目的左移,稍加修改放進點陣移屏代碼也就實現(xiàn)了左移了,但是代碼中可以看到我給了每一個字節(jié)都加了字節(jié)緩存位有沒有什么辦法去掉這些緩存位,畢竟32x32的點陣后續(xù)還要級聯(lián)那么xdata屬實有點太大了一塊屏加上字節(jié)緩存就是256字節(jié)每加一塊就會翻倍,雖然主控是stc8h8k容量完全夠了,或者有大佬知道其他逐行掃描左移代碼執(zhí)行效率高的方法。謝謝各位了
作者:
lkc8210
時間:
2022-12-18 13:41
不用緩存
Byte[1]=ZiMo[0+i*128+j*4]<<x | ZiMo[1+i*128+j*4]>>(7-x);
Byte[2]=ZiMo[1+i*128+j*4]<<x | ZiMo[2+i*128+j*4]>>(7-x);
Byte[3]=ZiMo[2+i*128+j*4]<<x | ZiMo[3+i*128+j*4]>>(7-x);
Byte[4]=ZiMo[3+i*128+j*4]<<x | ZiMo[4+i*128+j*4]>>(7-x);
ZiMo是字模數(shù)組
i是第幾個字(一個字是4char x 32 =128)
j是第幾行
x是位移
作者:
名字不是重點
時間:
2022-12-18 16:13
同樣的道理,把你之前的“字節(jié)”頂改為“位”頂就可以了。
以下是6個點陣塊(48*8)的移列操作,你參考 一下。
u8 i;
for(i=0;i<8;i++) //8行,6個點陣塊
{
dis_buf[i+40]<<=1; if(dis_buf[i+32]&0x80) dis_buf[i+40]|=0x01;// 第六個點陣塊
dis_buf[i+32]<<=1; if(dis_buf[i+24]&0x80) dis_buf[i+32]|=0x01;// 第五個點陣塊
dis_buf[i+24]<<=1; if(dis_buf[i+16]&0x80) dis_buf[i+24]|=0x01;// 第四個點陣塊
dis_buf[i+16]<<=1; if(dis_buf[i+8]&0x80) dis_buf[i+16]|=0x01;// 第三個點陣塊
dis_buf[i+8]<<=1; if(dis_buf[i]&0x80) dis_buf[i+8]|=0x01;// 第二個點陣塊
dis_buf[i]<<=1; // 第一個點陣塊
}
歡迎光臨 (http://www.torrancerestoration.com/bbs/)
Powered by Discuz! X3.1