| 
 
 
 
 | 
 Detailed Descriptionlibplayerc is a client library for the Player robot device server. It is written in C to maximize portability, and in the expectation that users will write bindings for other languages (such as Python and Java) against this library; Python bindings are already available.
libplayerc is based on a device proxy model, in which the client maintains a local proxy for each of the devices on the remote server. Thus, for example, one can create local proxies for thepositionandlaserdevices. There is also a specialclientproxy, used to control the Player server itself.
Programs using libplayerc will generally have the following structure: 
 
#include <stdio.h>
#include "playerc.h"
int main(int argc, const char **argv)
{
  int i;
  playerc_client_t *client;
  playerc_position_t *position;
  
  
  client = playerc_client_create(NULL, "localhost", 6665);
  if (playerc_client_connect(client) != 0)
  {
    fprintf(stderr, "error: %s\n", playerc_error_str());
    return -1;
  }
  
  
  position = playerc_position_create(client, 0);
  if (playerc_position_subscribe(position, PLAYER_ALL_MODE) != 0)
  {
    fprintf(stderr, "error: %s\n", playerc_error_str());
    return -1;
  }
  
  playerc_position_enable(position, 1);
  
  playerc_position_set_cmd_vel(position, 0, 0, 0.1, 1);
  for (i = 0; i < 200; i++)
  {
    
    playerc_client_read(client);
    printf("position : %f %f %f\n",
           position->px, position->py, position->pa);
  } 
  
  playerc_position_unsubscribe(position);
  playerc_position_destroy(position);
  playerc_client_disconnect(client);
  playerc_client_destroy(client);
  return 0;
}
This example can be built using the commands:  
$ gcc -c simple.c -o simple.o
$ gcc -lm -lplayerc simple.o -o simple
 
Make sure that playerc.his installed somewhere in you include path, and thatlibplayerc.ais in your library path. 
The above program can be broken into six steps, as follows. 
 
Detailed information for each proxy can be found in the Reference section.
Create and connect a client proxy.
 
 
client = playerc_client_create(NULL, "localhost", 6665);
playerc_client_connect(client);
The createfunction creates a new client proxy and returns a pointer to be used in future function calls (localhostshould be replaced with the network host name of the robot). Theconnectfunction notifies the Player server that a new client wishes to recieve data.
Create and subscribe a device proxy.
 
 
position = playerc_position_create(client, 0);
playerc_position_subscribe(position, PLAYER_ALL_MODE);
The createfunction creates a new position device proxy and returns a pointer to be used in future function calls. Thesubscribefunction notifies the Player server that the client is using the position device, and that the client expects to both send commands and recieve data (PLAYER_MODE_ALL).
Configure the device, send commands.
 
 
playerc_position_enable(position, 1);
playerc_position_set_speed(position, 0, 0, 0.1);
The enablefunction sends a configuration request to the server, changing the robot's motor state fromofftoon, thereby allowing the robot to move. Thesetspeedfunction sends a new motor speed, in this case commanding the robot to turn on the spot.
 
Note that most Player devices will accept both asynchronous command and synchronous configuration requests. Sending commands is analogous using the standard Unix writedevice interface, while sending configuration requests is analogous to using theioctlinterface. For the most part,libplayerchides the distinction between these two interfaces. Users should be aware, however, that while commands are always handled promptly by the server, configuration requests may take significant time to complete. If possible, configuration requests should therefore be restricted to the initialization phase of the program. 
Read data from the device.
 
 
playerc_client_read(client);
printf("position : %f %f %f\n", position->px, ... );
The readfunction blocks until new data arrives from the Player server. This data may be from one of the subscribed devices, or it may be from the server itself (which sends regular synchronization messages to all of its clients). Thereadfunction inspects the incoming data and automatically updates the elements in the appropriate device proxy. This function also returns a pointer to the proxy that was updated, so that user programs may, if desired, trigger appropriate events on the arrival of different kinds of data.
Unsubscribe and destroy the device proxy.
 
 
playerc_position_unsubscribe(position);
playerc_position_destroy(position);
The unsubscribefunction tells the Player server that the client is no longer using this device. Thedestroyfunction then frees the memory associated with the device proxy; thedevicepointer is now invalid and should be not be re-used.
Disconnect and destroy the client proxy.
 
 
playerc_client_disconnect(client);
playerc_client_destroy(client);
The disconnectfunction tells the server that the client is shutting down. Thedestroyfunction then frees the memory associated with the client proxy; theclientpointer is now invalid and should be not be re-used.
 
 Generated on Tue May 3 14:16:13 2005 for Player by
  1.3.6 |