已屏蔽 原因:{{ notice.reason }}已屏蔽
{{notice.noticeContent}}
~~空空如也
写了 3轴的数据收集及 手动控制 还有通信协议的框架也东基本定型


#include<reg52.h>
#include <intrins.h>     //内部包含延时函数 _nop_();
#define uchar unsigned char
#define uint  unsigned int
unsigned char flag1,flag,a,e1,e2,e3,e4,e5,e6,e7,e8,e9,m,a1,i,x,u,r,N,j,jj,z3,t,w,zdw,x1,z4,xmai,aa,zs;
sbit  key1 = P3^2;       //正转
sbit  key2 = P3^3;       //反转
sbit  key3 = P3^4;       //停止
sbit  key4 = P3^5;
sbit  key5 = P3^6;      
sbit  key6 = P3^7;
void  xjfj();    
void  yjfj();
void  zjfj();
void  xjzj();
void  yjzj();
void  zjzj();
void  js();
void delay(uint t);
sbit w1=P2^7;
sbit w2=P2^6;
sbit w3=P2^5;
sbit w4=P2^4;
uchar code table[]={0x28,0xeb,0x32,0xa2,0xe1,0xa4,0x24,0xea,0x20,0xa0,0xff};
uchar code zj1[8]={0x01,0x03,0x02,0x06,0x04,0x0c,0x08,0x09}; //P10~3. P20-3
uchar code fj1[8]={0x09,0x08,0x0c,0x04,0x06,0x02,0x03,0x01}; //P10~3. P20-3

uchar code zj2[8]={0x10,0x30,0x20,0x60,0x40,0xc0,0x80,0x90}; ////P14~7.
uchar code fj2[8]={0x90,0x80,0xc0,0x40,0x60,0x20,0x30,0x10}; ////P14~7.
void main()
{
    TMOD=0x20;//设置定时器1为工作方式2
    TH1=0xfd;
    TL1=0xfd;
    TR1=1;
    REN=1;
    SM0=0;
    SM1=1;
    EA=1;
    ES=1;
e1=0;
e2=0;
e3=0;
e4=0;
e5=0;
e6=0;
e7=0;
e8=0;
e9=0;
a=0;
zs=5;
//电机远转圈数
while(1)
        {
/*
P0=table[a];
w1=0;
P0=0xff;
w1=1;
P0=table[a];
w2=0;
P0=0xff;
w2=1;
*/
//************************************

if(a1==0)
{
if(a==1) //X轴前进
{
xjzj();
}//jj1

if(a==2)
{
xjfj();
}
if(a==3)
{
yjzj();
}

if(a==4)
{
yjfj();
}
if(a==5)
{
zjzj();
}

if(a==6)
{
zjfj();
}

}// a1==0


if(a1==1)
{
P0=table[zs];
w3=0;
P0=0xff;
w3=1;
if(a==1)
{
zs++;
a=0;
}

if(a==2)
{
zs--;
a=0;

}
if(zs>9)
{
zs=9;
}
if(zs<1)
{
zs=1;
}

}//a1==1

if(a1==3)
{
if(a==1)
{
xjzj();
e1++;
js();
}
if(a==2)
{
yjzj();
e1++;
js();
}
}//a1==3

if(a1==4)
{

if(a==1)
{
P0=table[e4];
w1=0;
P0=0xff;
w1=1;
P0=table[e3];
w2=0;
P0=0xff;
w2=1;
P0=table[e2];
w3=0;
P0=0xff;
w3=1;
P0=table[e1];
w4=0;
P0=0xff;
w4=1;
}
if(a==2)
{
P0=table[e8];
w1=0;
P0=0xff;
w1=1;
P0=table[e7];
w2=0;
P0=0xff;
w2=1;
P0=table[e6];
w3=0;
P0=0xff;
w3=1;
P0=table[e5];
w4=0;
P0=0xff;
w4=1;
}

if(a==3)
{

P0=table[e9];
w4=0;
P0=0xff;
w4=1;
}              
if(a==9)
{
e1=0;
e2=0;
e3=0;
e4=0;
e5=0;
e6=0;
e7=0;
e8=0;
e9=0;
}

}//a1==4
//------------------------------------
        }// w1
}//m

void ser() interrupt 4
{
    RI=0;
//    P1=SBUF;
    aa=SBUF;
a=0;
a1=0;
for (m=0;m<aa;m++)
{
a++;
if(a>15)
{
a1++;
a=0;
}
if (a1>9)
{
a1=9;
}
}
//a1=a;

/*
N1=0;
N2=0;
N3=0;
for (m=0;m<a;m++)
{ N1++;
if(N1>9)
{
N2++;
N1=0;
}
if (N2>9)
{
N2=0;
N3++;
}

}
*/
}
/********************************************************/                
/********************************************************/                                                
/* 延时t毫秒
/* 11.0592MHz时钟,延时约1ms                                                                                          
/********************************************************/
void delay(uint t)
{                          
   uint k;
   while(t--)
   {
     for(k=0; k<125; k++)
     { }
   }
}
/********************************************************
/*
/*步进电机正转 x轴
/********************************************************/
void  xjzj()
{
   //uchar i;
   //uint  j;
   for (j=0; j<1; j++)         //转1*n圈
    {
                      //退出此循环程序
     for (i=0; i<8; i++)    
    //for (i=0; i<2; i++)    //一个周期转30度
        {
          P1 = zj1[i];          //取数据
          delay(zs);            //调节转速
        }
    }
}
/********************************************************
/********************************************************/
/*步进电机反转 x轴
/********************************************************/
void  xjfj()
{
   //uchar i;
   //uint  j;
   for (j=0; j<1; j++)         //转1*n圈
    {
                      //退出此循环程序
     for (i=0; i<8; i++)    
    //for (i=0; i<2; i++)    //一个周期转30度
        {
          P1 = fj1[i];          //取数据
          delay(zs);            //调节转速
        }
    }
}


/********************************************************
/*
/*步进电机正转 y轴
/********************************************************/
void  yjzj()
{
   //uchar i;
   //uint  j;
   for (j=0; j<1; j++)         //转1*n圈
    {
                      //退出此循环程序
     for (i=0; i<8; i++)    
    //for (i=0; i<2; i++)    //一个周期转30度
        {
          P1 = zj2[i];          //取数据
          delay(zs);            //调节转速
        }
    }
}
/********************************************************
/********************************************************/
/*步进电机反转 y轴
/********************************************************/
void  yjfj()
{
   //uchar i;
   //uint  j;
   for (j=0; j<1; j++)         //转1*n圈
    {
                      //退出此循环程序
     for (i=0; i<8; i++)    
    //for (i=0; i<2; i++)    //一个周期转30度
        {
          P1 = fj2[i];          //取数据
          delay(zs);            //调节转速
        }
    }
}

/********************************************************
/*
/*步进电机正转 z轴
/********************************************************/
void  zjzj()
{
   //uchar i;
   //uint  j;
   for (j=0; j<1; j++)         //转1*n圈
    {
                      //退出此循环程序
     for (i=0; i<8; i++)    
    //for (i=0; i<2; i++)    //一个周期转30度
        {
          P2 = zj1[i];          //取数据
          delay(zs);            //调节转速
        }
    }
}
/********************************************************
/********************************************************/
/*步进电机反转 z轴
/********************************************************/
void  zjfj()
{
   //uchar i;
   //uint  j;
   for (j=0; j<1; j++)         //转1*n圈
    {
                      //退出此循环程序
     for (i=0; i<8; i++)    
    //for (i=0; i<2; i++)    //一个周期转30度
        {
          P2 = fj1[i];          //取数据
          delay(zs);            //调节转速
        }
    }
}
void  js()
{

if(e1>9)
{
e2++;
e1=0;

//------------------------

//------------------------

if(e2>9)
{
e3++;
e2=0;

}
}//e1~2

if(e3>9)
{
e3=0;
e4++;
if(e4>9)
{
e4=0;
e5++;
}
}//e3 ~4


if(e5>9)
{
e5=0;
e6++;
if(e6>9)
{
e6=0;
e7++;
}
}// e5~6

if(e7>9)
{
e7=0;
e8++;
if(e8>9)
{
e8=0;
e9++;
}
}//e7~8
if(e9>9)
{
e9=9;
}
}//voi
文号 / 214167

千古风流
名片发私信
学术分 4
总主题 494 帖总回复 6744 楼拥有证书:学者 笔友
注册于 2009-01-02 22:19最后登录 2018-01-10 01:36
主体类型:个人
所属领域:无
认证方式:邮箱
IP归属地:未同步

个人简介

.

文件下载
加载中...
{{errorInfo}}
{{downloadWarning}}
你在 {{downloadTime}} 下载过当前文件。
文件名称:{{resource.defaultFile.name}}
下载次数:{{resource.hits}}
上传用户:{{uploader.username}}
所需积分:{{costScores}},{{holdScores}}下载当前附件免费{{description}}
积分不足,去充值
文件已丢失

当前账号的附件下载数量限制如下:
时段 个数
{{f.startingTime}}点 - {{f.endTime}}点 {{f.fileCount}}
视频暂不能访问,请登录试试
仅供内部学术交流或培训使用,请先保存到本地。本内容不代表科创观点,未经原作者同意,请勿转载。
音频暂不能访问,请登录试试
投诉或举报
加载中...
{{tip}}
请选择违规类型:
{{reason.type}}

空空如也

插入资源
全部
图片
视频
音频
附件
全部
未使用
已使用
正在上传
空空如也~
上传中..{{f.progress}}%
处理中..
上传失败,点击重试
等待中...
{{f.name}}
空空如也~
(视频){{r.oname}}
{{selectedResourcesId.indexOf(r.rid) + 1}}
处理中..
处理失败
插入表情
我的表情
共享表情
Emoji
上传
注意事项
最大尺寸100px,超过会被压缩。为保证效果,建议上传前自行处理。
建议上传自己DIY的表情,严禁上传侵权内容。
点击重试等待上传{{s.progress}}%处理中...已上传,正在处理中
空空如也~
处理中...
处理失败
加载中...
草稿箱
加载中...
此处只插入正文,如果要使用草稿中的其余内容,请点击继续创作。
{{fromNow(d.toc)}}
{{getDraftInfo(d)}}
标题:{{d.t}}
内容:{{d.c}}
继续创作
删除插入插入
插入公式
评论控制
加载中...
文号:{{pid}}
加载中...
详情
详情
推送到专栏从专栏移除
设为匿名取消匿名
查看作者
回复
只看作者
加入收藏取消收藏
收藏
取消收藏
折叠回复
置顶取消置顶
评学术分
鼓励
设为精选取消精选
管理提醒
编辑
通过审核
评论控制
退修或删除
历史版本
违规记录
投诉或举报
加入黑名单移除黑名单
查看IP
{{format('YYYY/MM/DD HH:mm:ss', toc)}}
ID: {{user.uid}}