CADP 第四組 期末分組網站

第二版 << Previous Next >> v-rep-api 參考資料

最新版

設定檔與程式檔下載

原始碼:

import vrep
import sys, math
# child threaded script: 
# 內建使用 port 19997 若要加入其他 port, 在  serve 端程式納入
#simExtRemoteApiStart(19999)
 
vrep.simxFinish(-1)
 
clientID = vrep.simxStart('127.0.0.1', 19997, True, True, 5000, 5)
 
if clientID!= -1:
    print("Connected to remote server")
else:
    print('Connection not successful')
    sys.exit('Could not connect')
 
#errorCode,Revolute_joint_handle=vrep.simxGetObjectHandle(clientID,'Prismatic_joint',vrep.simx_opmode_oneshot_wait)
errorCode,Prismatic_joint_handle=vrep.simxGetObjectHandle(clientID,'Prismatic_joint',vrep.simx_opmode_oneshot_wait)
errorCode,Prismatic_joint1_handle=vrep.simxGetObjectHandle(clientID,'Prismatic_joint1',vrep.simx_opmode_oneshot_wait)
errorCode,Prismatic_joint0_handle=vrep.simxGetObjectHandle(clientID,'Prismatic_joint0',vrep.simx_opmode_oneshot_wait)
 
if errorCode == -1:
    print('Can not find left or right motor')
    sys.exit()
    

#errorCode=vrep.simxSetJointTargetVelocity(clientID,Revolute_joint_handle,2, vrep.simx_opmode_oneshot_wait)

def setJointPositionz(poi, steps):
    for i  in range(steps):
        position_z=vrep.simxGetJointPosition(clientID,Prismatic_joint_handle,vrep.simx_opmode_oneshot_wait)
        z = position_z[1]
        print('z =' ,z)
        errorCode=vrep.simxSetJointPosition(clientID, Prismatic_joint_handle, z-poi, vrep.simx_opmode_oneshot_wait)
        
def setJointPositiony(poi, steps):
    for i  in range(steps):
        position_y=vrep.simxGetJointPosition(clientID,Prismatic_joint1_handle,vrep.simx_opmode_oneshot_wait)
        y = position_y[1]
        print('y =' ,y)
        errorCode=vrep.simxSetJointPosition(clientID, Prismatic_joint1_handle, poi+y, vrep.simx_opmode_oneshot_wait)
        
def setJointPositionx(poi, steps):
    for i  in range(steps):
        position_x=vrep.simxGetJointPosition(clientID,Prismatic_joint0_handle,vrep.simx_opmode_oneshot_wait)
        x = position_x[1]
        print('x =' , x)
        errorCode=vrep.simxSetJointPosition(clientID, Prismatic_joint0_handle, poi+x, vrep.simx_opmode_oneshot_wait)
        
def setJointPositionO(poi, steps):
    errorCode=vrep.simxSetJointPosition(clientID, Prismatic_joint_handle, 0.11, vrep.simx_opmode_oneshot_wait)
    errorCode=vrep.simxSetJointPosition(clientID, Prismatic_joint1_handle, -0.157, vrep.simx_opmode_oneshot_wait)
    errorCode=vrep.simxSetJointPosition(clientID, Prismatic_joint0_handle,-0.09, vrep.simx_opmode_oneshot_wait)
        
def JointGoPosition(x,y,z):
    
    
        if x >= 0 and y >= 0 and z >= 0 :
            x_step = x*10
            y_step = y*10
            z_step = z*10
            setJointPositionx(0.001, x_step)
            setJointPositiony(0.001, y_step)
            setJointPositionz(0.001, z_step)
        elif x < 0 and y >= 0 and z >= 0 :
            x_step = x*-10
            y_step = y*10
            z_step = z*10
            setJointPositionx(-0.001, x_step)
            setJointPositiony(0.001, y_step)
            setJointPositionz(0.001, z_step)
        elif x >= 0 and y < 0 and z >= 0 :
            x_step = x*10
            y_step = y*-10
            z_step = z*10
            setJointPositionx(0.001, x_step)
            setJointPositiony(-0.001, y_step)
            setJointPositionz(0.001, z_step)
        elif x >= 0 and y >= 0 and z < 0 :
            x_step = x*10
            y_step = y*10
            z_step = z*-10
            setJointPositionx(0.001, x_step)
            setJointPositiony(0.001, y_step)
            setJointPositionz(-0.001, z_step)
        elif x < 0 and y < 0 and z >= 0 :
            x_step = x*-10
            y_step = y*-10
            z_step = z*10
            setJointPositionx(-0.001, x_step)
            setJointPositiony(-0.001, y_step)
            setJointPositionz(0.001, z_step)
        elif x >= 0 and y < 0 and z < 0 :
            x_step = x*10
            y_step = y*-10
            z_step = z*-10
            setJointPositionx(0.001, x_step)
            setJointPositiony(-0.001, y_step)
            setJointPositionz(-0.001, z_step)
        elif x < 0 and y >= 0 and z < 0 :
            x_step = x*-10
            y_step = y*10
            z_step = z*-10
            setJointPositionx(-0.001, x_step)
            setJointPositiony(0.001, y_step)
            setJointPositionz(-0.001, z_step)
        else:
            x_step = x*-10
            y_step = y*-10
            z_step = z*-10
            setJointPositionx(-0.001, x_step)
            setJointPositiony(-0.001, y_step)
            setJointPositionz(-0.001, z_step)

#回歸(0,0,0)
setJointPositionO(0, 1)

#移動座標(x,y,z)(增量座標)
JointGoPosition(0,10,0)

第二版 << Previous Next >> v-rep-api 參考資料