標(biāo)題: [求助]誰能詳細(xì)解釋下點陣左移的那個語句 [打印本頁]

作者: wtf3505    時間: 2012-6-16 11:09
標(biāo)題: [求助]誰能詳細(xì)解釋下點陣左移的那個語句

板子附帶的程序中那個點陣掃描里有幾句我不懂,網(wǎng)上查了很多,實現(xiàn)移動都是這幾句,大同小異,我想問下這幾句怎么理解,我怎么老看不明白呢

下面是板子附帶的程序:

/*8X8行掃描,左移顯示
如果將掃描方式改為列掃描,那么左右移動的程序就容易寫了,但當(dāng)點陣比較巨大
并且硬件已經(jīng)定下時,改變掃描方式不是好方法,甚至不可能實現(xiàn)。這里是以行
掃描為例(逐行取字模),第一次取字碼數(shù)組中的第1~8個數(shù)據(jù)到點陣列輸入端,
行碼 掃描1~8行。第二次將第一次的 1~8個數(shù)據(jù)都循環(huán)左(右)移一位,并且
將第9個數(shù)據(jù)的最高位移到第二次數(shù)據(jù)的最低處,再輸入到列端口,行掃描1~8行。
即每次掃描都要把前一次掃描的列碼左移一位。
程序如下:
*/
#include<reg52.h>
#include "51hei.H"
#define uchar unsigned char
#define uint unsigned int
uchar code TAB[]={0xFF,0xF7,0xFB,0x81,0xFB,0xF7,0xFF,0xFF};
uchar i,t,j=0;
delay(uchar t)
{
while (t--)
{;}
}
void main(void)
{ uchar T,Y,Q,d;
P2=0x75;
while(1)
   {
   for(Q=0;Q<8;Q++)
    for(T=0;T<50;T++)    //速度
      {
    d=0x01;
out164(d);
          for(i=0;i<8;i++)
         {
       Y=TAB[i+1]*256+TAB;
    Y=Y<<(7-Q)|Y>>Q;
    P0=Y%256;
    delay(60);
    d=d<<1|d>>7;
 P0=0xff; // 消隱,很重要,不加要紅一片
out164(d);
       }
    }
}
}
其中    Y=Y<<(7-Q)|Y>>Q;
是實現(xiàn)循環(huán)左移的嗎?

    d=d<<1|d>>7;
這句好像那個點陣移動的程序都有,我想是實現(xiàn)左移的(右移就是<<換成>>),怎么理解呢?怎么這樣就實現(xiàn)了左移呢?

我想還有很多新手和我一樣吧,請幫忙啊


作者: wy704972600    時間: 2012-6-23 19:15

d=d<<1|d>>7;是為了實現(xiàn)循環(huán)左移。比如d為0X01,d=d<<1|d>>7;后為0x02.而如果為0X80,d=d<<1|d>>7;后為0X01;根據(jù)符號的優(yōu)先級來計算


作者: wtf3505    時間: 2012-6-29 17:58
以下是引用wy704972600在2012-6-23 19:15:53的發(fā)言:

d=d<<1|d>>7;是為了實現(xiàn)循環(huán)左移。比如d為0X01,d=d<<1|d>>7;后為0x02.而如果為0X80,d=d<<1|d>>7;后為0X01;根據(jù)符號的優(yōu)先級來計算

謝謝!我開始就是不理解0x01經(jīng)過"d=d<<1|d>>7;"后變?yōu)?x02,因為d=d<<1;就已經(jīng)變?yōu)?x02,為什么還要|d>>7呢 一直糾結(jié)在這...菜鳥就是這樣子的,再次謝謝!


作者: chaikunquan    時間: 2013-8-18 15:50
wtf3505 發(fā)表于 2012-6-29 17:58
以下是引用wy704972600在2012-6-23 19:15:53的發(fā)言:
d=d&lt;&lt;1|d&gt;&gt;7;是為了實現(xiàn)循環(huán)左移。比如d為0X ...

我覺得就是為了防止數(shù)據(jù)丟失吧,反正他們是或的關(guān)系。而且后面那個只針對0x01




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1