This repository is for communication between different platforms using WebSocket. The purpose of this repository is to open a server on a Linux-based platform and run a client on other platforms (Windows, Mac, Android) to send messages to Linux. The messages are then converted to ROS coordinates and sent as commands to control the robot through ROS topics. In other words, it helps to control the robot from other platforms. For more details, please refer to this YouTube video and Notion. In the video, the implementation allows controlling the robot by pressing buttons in an app.
-
This environment requires Python 3.x or later.
- For Windows: Download from the Python official website.
- For macOS:
brew install python
- For Linux:
sudo apt-get install python3
-
Install asyncio:
pip install asyncio
-
Install websockets:
pip install websockets
-
(for the server) Install ROS. Refer to the ROS official website for installation instructions. (In this version, Linux 18.04 LTS and Melodic was used. Therefore, the operation on other platforms or distributions is not guaranteed.)
- 'server.py' is a server that receives messages and converts them into coordinates to send move commands to the robot using a topic.
- 'client.py' is a client for testing the communication. It is a simple client that sends any input to the server.
Please run the server and client on the desired platforms.
-
Connect to the same Wi-Fi network. Please note that it may not work on networks with certain security, such as those in secure company or institutional environments. It is recommended to use a personal network.
-
Clone this repository to your desired location.
git clone https://github.com/khu-wafer/robot_communication
-
Navigate to the downloaded repository and modify the {YOUR_IP} in server.py and client.py. Replace {YOUR_IP} with your actual IP address. For example, if your IP address is 123.45.6.78, replace {YOUR_IP} with 123.45.6.78
-
Modify the messages and coordinates in server.py according to your needs. For example, if you want the robot to move to specific coordinates when receiving the message '1', modify the code as follows:
if message == '1':
publish_rostopic_command(-0.587, 2.892, 0.177, 0.984)
You can refer to the SLAM Repository for robot coordinates.
5-1. Run roscore.
roscore
5-2. Open a terminal, navigate to the location of server.py, and run the server. If the following message appears, the server is running successfully.
python server.py
5-3. Open a terminal, navigate to the location of client.py, and run the client. If the following message appears, the client is running successfully.
python client.py
5-4. Enter the message you want to send.
5-5. If the message is successfully received, the server will display the message as shown below.
This code is compatible with Python 3 or higher. The code has been tested on Windows, macOS, Android, and Linux platforms. It may not work on other platforms, so appropriate modifications may be necessary.
If you have any questions or find any bugs, please feel free to open an issue or pull request.