找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3392|回復: 2
收起左側

求8*8led點陣動畫案例

[復制鏈接]
ID:151303 發(fā)表于 2016-11-30 20:13 | 顯示全部樓層 |閱讀模式
求8*8led點陣動畫案例
回復

使用道具 舉報

ID:375551 發(fā)表于 2018-7-21 18:00 | 顯示全部樓層

// 動畫Delay迴圈
void delay_ms(uint16_t x)
{
  uint8_t y, z;
  for ( ; x > 0 ; x--){
    for ( y = 0 ; y < 90 ; y++){
      for ( z = 0 ; z < 6 ; z++){
        asm volatile ("nop");
      }
    }
  }
}



//Z axiz的下雨動畫
void shift (char axis, int direction)
{
        int i, x ,y;
        int ii, iii;
        int state;

        for (i = 0; i < 8; i++)
        {
                if (direction == -1)
                {
                        ii = i;
                } else
                {
                        ii = (7-i);
                }        
        
        
                for (x = 0; x < 8; x++)
                {
                        for (y = 0; y < 8; y++)
                        {
                                if (direction == -1)
                                {
                                        iii = ii+1;
                                } else
                                {
                                        iii = ii-1;
                                }
                                
                                if (axis == AXIS_Z)
                                {
                                        state = getvoxel(x,y,iii);
                                        altervoxel(x,y,ii,state);
                                }
                                
                                if (axis == AXIS_Y)
                                {
                                        state = getvoxel(x,iii,y);
                                        altervoxel(x,ii,y,state);
                                }
                                
                                if (axis == AXIS_X)
                                {
                                        state = getvoxel(iii,y,x);
                                        altervoxel(ii,y,x,state);
                                }
                        }
                }
        }
        
        if (direction == -1)
        {
                i = 7;
        } else
        {
                i = 0;
        }        
        
        for (x = 0; x < 8; x++)
        {
                for (y = 0; y < 8; y++)
                {
                        if (axis == AXIS_Z)
                                clrvoxel(x,y,i);
                                
                        if (axis == AXIS_Y)
                                clrvoxel(x,i,y);
                        
                        if (axis == AXIS_X)
                                clrvoxel(i,y,x);
                }
        }
}
[/pre]
回復

使用道具 舉報

ID:375551 發(fā)表于 2018-7-21 18:10 | 顯示全部樓層

// 動畫Delay迴圈
void delay_ms(uint16_t x)
{
  uint8_t y, z;
  for ( ; x > 0 ; x--){
    for ( y = 0 ; y < 90 ; y++){
      for ( z = 0 ; z < 6 ; z++){
        asm volatile ("nop");
      }
    }
  }
}



//Z axiz的下雨動畫
void shift (char axis, int direction)
{
        int i, x ,y;
        int ii, iii;
        int state;

        for (i = 0; i < 8; i++)
        {
                if (direction == -1)
                {
                        ii = i;
                } else
                {
                        ii = (7-i);
                }        
        
        
                for (x = 0; x < 8; x++)
                {
                        for (y = 0; y < 8; y++)
                        {
                                if (direction == -1)
                                {
                                        iii = ii+1;
                                } else
                                {
                                        iii = ii-1;
                                }
                                
                                if (axis == AXIS_Z)
                                {
                                        state = getvoxel(x,y,iii);
                                        altervoxel(x,y,ii,state);
                                }
                                
                                if (axis == AXIS_Y)
                                {
                                        state = getvoxel(x,iii,y);
                                        altervoxel(x,ii,y,state);
                                }
                                
                                if (axis == AXIS_X)
                                {
                                        state = getvoxel(iii,y,x);
                                        altervoxel(ii,y,x,state);
                                }
                        }
                }
        }
        
        if (direction == -1)
        {
                i = 7;
        } else
        {
                i = 0;
        }        
        
        for (x = 0; x < 8; x++)
        {
                for (y = 0; y < 8; y++)
                {
                        if (axis == AXIS_Z)
                                clrvoxel(x,y,i);
                                
                        if (axis == AXIS_Y)
                                clrvoxel(x,i,y);
                        
                        if (axis == AXIS_X)
                                clrvoxel(i,y,x);
                }
        }
}
[/pre]
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復 返回頂部 返回列表