rosaria/Legacy/Aria/ArNetworking/pythonExamples/simple.py

78 lines
2.1 KiB
Python
Raw Normal View History

2021-12-16 15:07:59 +01:00
from AriaPy import *
from ArNetworkingPy import *
import sys
# This example demonstrates how to use ArNetworking in Python.
# Global library initialization, just like the C++ API:
Aria_init()
# Create a robot object:
robot = ArRobot()
# make a gyro
gyro = ArAnalogGyro(robot)
#sonar, must be added to the robot
sonarDev = ArSonarDevice()
#add the sonar to the robot
robot.addRangeDevice(sonarDev)
# make the core server object:
server = ArServerBase()
# Create a "simple connector" object and connect to either the simulator
# or the robot. Unlike the C++ API which takes int and char* pointers,
# the Python constructor just takes argv as a list.
print "Connecting..."
con = ArSimpleConnector(sys.argv)
if (not con.connectRobot(robot)):
print "Could not connect to robot, exiting"
Aria_exit(1)
# Open the server on port 7272:
if (not server.open(7272)):
print "Could not open server, exiting"
Aria_exit(1)
# Create various services and attach them to the core server
serverInfoRobot = ArServerInfoRobot(server, robot)
serverInfoSensor = ArServerInfoSensor(server, robot)
drawings = ArServerInfoDrawings(server)
drawings.addRobotsRangeDevices(robot)
# ways of moving the robot
modeStop = ArServerModeStop(server, robot)
modeRatioDrive = ArServerModeRatioDrive(server, robot)
modeWander = ArServerModeWander(server, robot)
modeStop.addAsDefaultMode()
modeStop.activate()
# set up the simple commands ("custom commands" in MobileEyes)
commands = ArServerHandlerCommands(server)
# add the simple commands for the microcontroller
uCCommands = ArServerSimpleComUC(commands, robot)
# add the simple commands for logging
loggingCommands = ArServerSimpleComMovementLogging(commands, robot)
# add the simple commands for the gyro
gyroCommands = ArServerSimpleComGyro(commands, robot, gyro)
# Add the simple command for logging the robot config and orig robot config
configCommands = ArServerSimpleComLogRobotConfig(commands, robot)
# Run the robot and server threads in the background:
print "Running..."
robot.runAsync(1)
server.runAsync()
robot.enableMotors()
robot.waitForRunExit()
Aria_exit(0)