找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2930|回复: 2
收起左侧

求8*8led点阵动画案例

[复制链接]
ID:151303 发表于 2016-11-30 20:13 | 显示全部楼层 |阅读模式
求8*8led点阵动画案例
回复

使用道具 举报

ID:375551 发表于 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 发表于 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]
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

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