久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2075|回復: 1
打印 上一主題 下一主題
收起左側

立方燈原碼

[復制鏈接]
跳轉到指定樓層
樓主
ID:251316 發表于 2017-11-20 10:54 來自手機 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
#include"3d8.h"
#include<reg52.h>
void reset()//復位
{
    Y=0xff;
    Z=0x00;
    X=0x00;
}
void delay(uint z)//延時函數
{
    uint x,y;
    for(x=z;x>0;x--)
        for(y=10;y>0;y--);
}
void delay_ms(uint z)//毫秒延時函數
{
    uint x,y;
    for(x=z;x>0;x--)
~ 4 / 9 ~
        for(y=10;y>0;y--);
}
void value_YZ_face(uchar x_date,uchar time)
{
    reset();
    Y=0xff;
    X=x_date;
    Z=~0xff;
    delay(time);
}
void value_XZ_face(uchar y_date,uchar time)
{
    reset();
    Y=y_date;
    X=0xff;
    Z=~0xff;
    delay(time);
}
void value_XY_face(uchar z_date,uchar time)
{
    reset();
    Y=0xff;
    X=0xff;
    Z=~z_date;
    delay(time);
}
void set_dot(uchar x,uchar y,uchar z,bit status,uchar time)
{
    reset();
    if(status)
        {
        Y = (1<<y);
        Z =~(1<<z);
        X = (1<<x);
        }
    else
        {
        Y =~(1<<y);
        Z = (1<<z);
        X =~(1<<x);
      
        }
    delay(time);
}
void set_line_X(uchar y,uchar z,uchar x_date,bit status,uchar time)//平行于X軸的線
{
    reset();
    if(status)
        {
        Y = (1<<y);
        Z =~(1<<z);
        }
    else
        {
        Y =~(1<<y);
        Z = (1<<z);
        }
    X=x_date;
    delay(time);
}
void set_line_Y(uchar x,uchar z,uchar y_date,bit status,uchar time)//平行于Y軸的線
{
    reset();
    Y=y_date;
    if(status)
        {
        Z =~(1<<z);
        X = (1<<x);
        }
    else
        {
        Z = (1<<z);
        X =~(1<<x);
        }
   
    delay(time);
}
void set_line_Z(uchar x,uchar y,uchar z_date,bit status,uchar time)//平行于Z軸的線
{    reset();    if(status)        {        Y = (1<<y);        Z=z_date;        X = (1<<x);        }    else        {        Y =~(1<<y);        Z=z_date;        X =~(1<<x);        }       delay(time);}void set_line(uchar x1,uchar y1,uchar z1,uchar x2,uchar y2,uchar z2,bit status,uchar time)//通過兩點坐標生成直線{    uchar i,i1,i2,x_flag=0,y_flag=0,z_flag=0;    char x,y,z;    x=x1-x2;y=y1-y2;z=z1-z2;           if(x!=0)        {        if(x<0)            {i=x2-x1;x_flag=2;}        else               {i=x1-x2;x_flag=1;}               }           if(y!=0)        {        if(y<0)            {i=y2-y1;y_flag=2;}        else               {i=y1-y2;y_flag=1;}        }              if(z!=0)        {        if(z<0)            {i=z2-z1;z_flag=2;}        else               {i=z1-z2;z_flag=1;}        }        /*SBUF='0'+i;              while(!TI);              TI=0;        SBUF=' ';              while(!TI);              TI=0;        SBUF='0'+x_flag;              while(!TI);              TI=0;        SBUF=' ';              while(!TI);              TI=0;        SBUF='0'+y_flag;              while(!TI);              TI=0;        SBUF=' ';              while(!TI);              TI=0;        SBUF='0'+z_flag;              while(!TI);              TI=0;        SBUF=' ';              while(!TI);              TI=0;*/              //i=x2-x1;x_flag=2;y_flag=2;z_flag=2;                                     for(i2=time;i2>0;i2--)        {~ 6 / 9 ~        x=x1;y=y1;z=z1;        for(i1=i+1;i1>0;i1--)            {            set_dot(x,y,z,status,3);            /*            switch(x_flag)                {                case 0:    ;break;                case 1:x-=1;break;                case 2:x+=1;break;                }            switch(y_flag)                {                case 0:    ;break;                case 1:y-=1;break;                case 2:y+=1;break;                }            switch(z_flag)                {                case 0:    ;break;                case 1:z-=1;break;                case 2:z+=1;break;                }*/            if(x_flag==1)                x-=1;            if(x_flag==2)                x+=1;            if(y_flag==1)                y-=1;            if(y_flag==2)                y+=1;            if(z_flag==1)                z-=1;            if(z_flag==2)                z+=1;            }        }}void set_solid_cube(uchar x1,uchar y1,uchar z1,uchar x2,uchar y2,uchar z2,bit status,uchar time)//實心立方體{    uchar X1,Y1,Z1,t;    if(x1>x2)        {t=x1;x1=x2;x2=t;}           if(y1>y2)        {t=y1;y1=y2;y2=t;}    if(z1>z2)        {t=z1;z1=z2;z2=t;}    reset();    X1 = ((0xff<<x1)&(0xff>>(7-x2)));    Y1 = ((0xff<<y1)&(0xff>>(7-y2)));    Z1 =~((0xff<<z1)&(0xff>>(7-z2)));    if(status)        {Y = Y1;X = X1;Z = Z1;}    else        {Y =~Y1;X =~X1;Z =~Z1;}    delay(time*10);          }void set_frame_cube(uchar x1,uchar y1,uchar z1,uchar x2,uchar y2,uchar z2,bit status,uchar time)//框架立方體~ 7 / 9 ~{    uchar X1,Y1,Z1,t,i;    if(x1>x2)        {t=x1;x1=x2;x2=t;}        /*SBUF='0'+x1;              while(!TI);              TI=0;        SBUF=' ';              while(!TI);              TI=0;        SBUF='0'+x2;              while(!TI);              TI=0;        SBUF=' ';              while(!TI);              TI=0;*/    if(y1>y2)        {t=y1;y1=y2;y2=t;}        /*SBUF='0'+y1;              while(!TI);              TI=0;        SBUF=' ';              while(!TI);              TI=0;        SBUF='0'+y2;              while(!TI);              TI=0;        SBUF=' ';              while(!TI);              TI=0;*/    if(z1>z2)        {t=z1;z1=z2;z2=t;}        /*SBUF='0'+z1;              while(!TI);              TI=0;        SBUF=' ';              while(!TI);              TI=0;        SBUF='0'+z2;              while(!TI);              TI=0;        SBUF=' ';              while(!TI);              TI=0;*/    reset();    X1 = ((0xff<<x1)&(0xff>>(7-x2)));    Y1 = ((0xff<<y1)&(0xff>>(7-y2)));    Z1 =~((0xff<<z1)&(0xff>>(7-z2)));    for(i=time;i>0;i--)        {        set_line_X(y1,z1,X1,status,5);        set_line_X(y1,z2,X1,status,5);        set_line_X(y2,z1,X1,status,5);        set_line_X(y2,z2,X1,status,5);           set_line_Y(x1,z1,Y1,status,5);        set_line_Y(x1,z2,Y1,status,5);~ 8 / 9 ~        set_line_Y(x2,z1,Y1,status,5);        set_line_Y(x2,z2,Y1,status,5);           set_line_Z(x1,y1,Z1,status,5);        set_line_Z(x1,y2,Z1,status,5);        set_line_Z(x2,y1,Z1,status,5);        set_line_Z(x2,y2,Z1,status,5);        /*SBUF='0'+y1;              while(!TI);              TI=0;        SBUF=' ';              while(!TI);              TI=0;        SBUF='0'+y2;              while(!TI);              TI=0;        SBUF=' ';              while(!TI);              TI=0;*/        }}
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:542523 發表于 2019-5-29 16:44 | 只看該作者
這啥都沒有也看不懂啊
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 中文字幕第一页在线 | 久久久www| 一二区电影| 中文字幕蜜臀 | 伊人性伊人情综合网 | 色www精品视频在线观看 | 亚洲一区中文字幕 | 欧美一区视频 | 一区二区三区视频在线 | 二区国产 | 成人精品鲁一区一区二区 | 久久久久网站 | 久久成人一区 | 视频精品一区二区三区 | 国产激情网 | 欧美精品久久久久 | 亚洲精品二区 | av午夜激情 | av成人在线观看 | 在线成人www免费观看视频 | 6996成人影院网在线播放 | 人人操日日干 | 天天操天天干天天曰 | 99久久婷婷国产精品综合 | 免费看国产片在线观看 | 成年男女免费视频网站 | 日韩中文一区二区三区 | 久久av网| 91天堂网 | 国产一区二区在线免费播放 | 国产乱肥老妇国产一区二 | 精品免费 | 欧美日韩中文在线 | 欧美一区二区三区在线 | 免费在线观看一区二区 | 中文字幕电影在线观看 | 美女天天操| 午夜一区二区三区在线观看 | 中文字幕国产视频 | 国产精品久久久久婷婷二区次 | 欧美三级在线 |