控制机械臂

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<unistd.h>
#include<sys/stat.h>
#include<sys/types.h>
#include<fcntl.h>
#include<pthread.h>
#include<sys/wait.h>
#include<signal.h>
#include<sys/socket.h>
#include<arpa/inet.h>
#include<netinet/in.h>
#include <termios.h>
#include <assert.h>

#define RED 0x00
#define BLUE 0x01
#define ERR_MSG(msg) do{\
	fprintf(stderr,"error in line:%d\n",__LINE__);\
	perror(msg);\
}while(0)
#define SER_IP "192.168.116.201"
#define SER_PORT 8888
#define CLI_IP SER_IP
int getch(){
    int c=0;
    struct termios org_opts, new_opts;
    int res=0;
    res=tcgetattr(STDIN_FILENO, &org_opts);
    assert(res==0);

    new_opts = org_opts;

    new_opts.c_lflag &= ~(ICANON | ECHO | ECHOE | ECHOK | ECHONL | ECHOPRT | ECHOKE | ICRNL);
    tcsetattr(STDIN_FILENO, TCSANOW, &new_opts);

    c=getchar();

    res=tcsetattr(STDIN_FILENO, TCSANOW, &org_opts);
    assert(res==0);
    return c;
}
int main(int argc, const char *argv[])
{
	int cfd=socket(AF_INET,SOCK_STREAM,0);
	if(cfd<0){
		ERR_MSG("socket");
		return -1;
	}
	//connect 
	struct sockaddr_in sin;
	sin.sin_family=AF_INET;
	sin.sin_port=ntohs(SER_PORT);
	sin.sin_addr.s_addr=inet_addr(SER_IP);
	if(connect(cfd,(struct sockaddr*)&sin,sizeof(sin))<0){
		ERR_MSG("connect");
		return -1;
	}
	char buf_red[5]={0};
	unsigned char buf_blue[5]={0};
	buf_red[0]=0xff;
	buf_red[1]=0x02;
	buf_red[2]=RED;
	buf_red[3]=0;
	buf_red[4]=0xff;
	buf_blue[0]=0xff;
	buf_blue[1]=0x02;
	buf_blue[2]=BLUE;
	buf_blue[3]=90;
	buf_blue[4]=0xff;
	int flag=0;
	char ctrl;
	while(1){
		flag=0;
		ctrl=getch();
		if('w'==ctrl){
			flag=1;
			if(buf_red[3]<90){
				buf_red[3]++;
			}
			else continue;
		}else if('s'==ctrl){
			flag=1;
			if(buf_red[3]>-90)
				buf_red[3]--;
			else continue;
		}else if('a'==ctrl){
			flag=2;
			if(buf_blue[3]<180)
				buf_blue[3]++;
			else continue;
		}else if('d'==ctrl){
			flag=2;
			if(buf_blue[3]>0)
				buf_blue[3]--;
			else continue;
		}else {
			if('q'==ctrl)break;
			else{
				putchar(10);
				printf("input invild\n");
				continue;
			}
		}
		if(1==flag){
		if(send(cfd,buf_red,sizeof(buf_red),0)<0){
			ERR_MSG("send");
			break;
		}}else if(2==flag){
		if(send(cfd,buf_blue,sizeof(buf_blue),0)<0){
			ERR_MSG("send");
			break;
		}}
		printf("ctrl success\n");
		usleep(100);
	}
	close(cfd);
	return 0;
}

  • 10
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
抓取和放置物品,具体代码如下: ``` // 定义输入输出 IB1: I BYTE; // 输入1,用于判断是否有物品需要抓取 IB2: I BYTE; // 输入2,用于判断机械手臂是否在初始位置 OB1: O BYTE; // 输出1,用于控制机械手臂的夹爪打开或关闭 OB2: O BYTE; // 输出2,用于控制机械手臂的运动方向 // 程序主体 ORG 100 // 程序从100开始 START: // 判断是否有物品需要抓取 LD IB1 // 载入输入1 ANI 01H // 与01H进行与运算,判断最后一位是否为1 JNZ GRAB // 如果最后一位为1,跳转到GRAB // 判断机械手臂是否在初始位置 LD IB2 // 载入输入2 ANI 01H // 与01H进行与运算,判断最后一位是否为1 JNZ PLACE // 如果最后一位为1,跳转到PLACE // 如果没有物品需要抓取也没有放置位置,无动作,跳转到END JMP END GRAB: // 控制机械手臂抓取物品 SETB OB1.0 // 打开夹爪 SETB OB2.1 // 向右运动 LCALL DELAY // 延时 CLR OB2.1 // 停止运动 CLR OB1.0 // 关闭夹爪 CLR IB1.0 // 将输入1最后一位清零,表示已经抓取物品 JMP START // 跳转到START PLACE: // 控制机械手臂放置物品 SETB OB1.0 // 打开夹爪 SETB OB2.0 // 向左运动 LCALL DELAY // 延时 CLR OB2.0 // 停止运动 CLR OB1.0 // 关闭夹爪 CLR IB2.0 // 将输入2最后一位清零,表示已经放置物品 JMP START // 跳转到START END: RET // 程序结束 // 延时函数 DELAY: MOV R0, #10 // 将R0赋值为10 LOOP1: MOV R1, #255 // 将R1赋值为255 LOOP2: DJNZ R1, LOOP2 // 循环计数 DJNZ R0, LOOP1 // 循环计数 RET // 延时结束 ``` 以上程序是一个简单的机械手臂控制程序,根据输入信号控制机械手臂的运动和夹爪的打开和关闭,实现抓取和放置物品的功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值