Blink an LED on ESP32 board with Tuya Link SDK

tuya link sdk

Tuya is an All-in-one IoT Platform that enables the user to build smart IoT solutions by connecting devices efficiently, securely, and reliably. This is a getting started article to set up the Tuya platform with the Espressif’s ESP32 boards via tuya link SDK. Further, we use it to control an LED through an Android device. When the switch in the Tuya Smart App is turned ON, the LED connected to the ESP32 board glows and vice versa.

Prerequisites

Hardware:

  • ESP32 board
  • LED with suitable ballast resistor
  • Breadboard, micro-USB cable, and connecting wires

Software:

GitHub Link: https://github.com/JayeshRajam/Tuya-ledapp.git

The ESP32 board is placed on a breadboard. The positive terminal of the LED is connected to digital pin 5 of the ESP32 board and the negative terminal is connected to the ground pin via the ballast resistor as shown in the following circuit diagram.

esp32 board hardware connections for tuya link sdk

Software Setup: Tuya IoT Platform

Login to your Tuya Account or if you don’t have an account then create one using the SignUp option.

Tuya Login Page

Once Logged In, an overview of the platform is visible. Click the Create button to start a new Project.

Tuya Dashboard

To develop the application for ESP32 click on ‘Can’t find the category?’. The following custom creation menu should appear.

Tuya Custom Category Creation

Fill the required fields as done above and click Create. A pop-up box will appear, just close it to get the following screen.

Tuya Function Dashboard

Here, we’ll add a custom function of the following settings.

Custom Function Creation

Click OK. The function will now be visible.

Tuya link SDK custom function visible

Tuya Smart Application Graphical User Interface (GUI) now needs to be developed. For that, simply switch to the Device Panel tab and select ‘Create Blank Panel’.

Device Panel Tab

Following are the steps to complete the UI Studio procedure.

You can always test and release the application before moving further. You can also visit this article to know more about the Tuya platform for designing and manufacturing smart home solutions.

Note: The testing procedure requires you to install and login to the Tuya Smart Application on your Android and enter the same login email id here.

UI test and release

UI Testing ProcessOnce back to the Tuya IoT platform, it’s now time to generate a license for Link SDK.

license generation for link SDK

Select Link SDK Cloud Access Mode from the Hardware Development Tab. Click on the ‘Select’ button provided to place the License order. Click ’Get 2 Free Licenses’ and complete the steps to finally download a .xlsx file with uuid and key.

Now it’s time to install tuyaos-link-sdk to avail connectivity to Tuya Smart Application via Python 3.x. On your Windows PC run the following commands to clone the GitHub repository and install the tuyaos-link-sdk.


tuyaos-link-sdk install python

Open the ledapp.py file from the GitHub repo in the editor. Edit and change the productid, uuid, authkey and the COM port of your connected ESP32 device in the file. We’ll further use this file in the output section of this article.

Software Setup: Tuya Smart Application

Install the Tuya Smart App from the Google Play Store of your Android Device.
Tuya Smart App Google Play Store

Login to your Account or if you don’t have one create one!

Tuya Smart Account Login

Now from the add device section click the scanner button to scan the QR code generated by the ledapp.py file.

Tuya Smart Add device  Tuya Smart Add device Options

Tuya Smart Scan

Now the ESP Application will be added to the All Devices section of the Tuya Smart App.

Tuya Smart App ESP Application

The Arduino IDE here is used to process the serial message from the desktop Python on the ESP32 board similar to the PhysicalPixel Built-in Example.
Add the ESP32 board in the Arduino IDE

Arduino IDE Boards ESP32

Board Manager URL: https://raw.githubusercontent.com/espressif/arduino-esp32/gh-pages/package_esp32_dev_index.json

When the incoming Byte over serial is ‘H’, the program turns the LED on. The LED is turned off when the incoming Byte is ‘L’. Remember to set the proper GPIO pin to which the LED is connected.

Output

Run the ledapp.py file using the command


Tuya link SDK Output 1.jpg

Tuya link SDK Output 2

Share this:

Support CNX Software! Donate via cryptocurrencies, become a Patron on Patreon, or purchase goods on Amazon or Aliexpress

Radxa Orion O6 Armv9 mini-ITX motherboard
Subscribe
Notify of
guest
The comment form collects your name, email and content to allow us keep track of the comments placed on the website. Please read and accept our website Terms and Privacy Policy to post a comment.
22 Comments
oldest
newest
Boardcon CM3588 Rockchip RK3588 System-on-Module designed for AI and IoT applications