Arduino Nano 33 IoT - DIYables Bluetooth App Slider
Overview
In this tutorial, we are going to learn how to use the Bluetooth Slider feature with the Arduino Nano 33 IoT. The slider gives you two independent controls on your smartphone that you can drag to send values (0–100 by default) wirelessly to your Arduino via BLE. You can use these values to adjust LED brightness, set motor speed, position a servo, or control anything that needs a variable numeric input — all without touching the board.
Note: The Arduino Nano 33 IoT only supports BLE (Bluetooth Low Energy). It does not support Classic Bluetooth. The DIYables Bluetooth App supports both BLE and Classic Bluetooth on Android, and BLE on iOS. Since this board uses BLE, the app works on both Android and iOS.

Features
- Dual Sliders: Two independent slider controls
- Configurable Range: Set minimum, maximum, and step values
- Real-Time Updates: Slider values sent instantly on change
- PWM Ready: Map slider values directly to PWM output
- Works on Android & iOS: BLE is supported on both platforms
- No Pairing Required: BLE auto-connects without manual pairing
- Low Power: BLE consumes less power than Classic Bluetooth
Hardware Preparation
Or you can buy the following kits:
| 1 | × | DIYables Sensor Kit (30 sensors/displays) | |
| 1 | × | DIYables Sensor Kit (18 sensors/displays) |
Additionally, some of these links are for products from our own brand, DIYables .
Arduino Nano 33 IoT Code
Detailed Instructions
Follow these instructions step by step:
- If this is your first time using the Arduino Nano 33 IoT, refer to the Arduino Nano 33 IoT getting started guide.
- Connect the Arduino Nano 33 IoT board to your computer using a Micro USB cable.
- Launch the Arduino IDE on your computer.
- Select Arduino Nano 33 IoT board and the appropriate COM port.
- Navigate to the Libraries icon on the left bar of the Arduino IDE.
- Search "DIYables Bluetooth", then find the DIYables Bluetooth library by DIYables
- Click Install button to install the library.

- You will be asked for installing some other library dependencies
- Click Install All button to install all library dependencies.

BLE Code
- On Arduino IDE, Go to File Examples DIYables Bluetooth ArduinoBLE_Slider example, or copy the above code and paste it to the editor of Arduino IDE
- Click Upload button on Arduino IDE to upload code to Arduino Nano 33 IoT
- Open the Serial Monitor
- Check out the result on Serial Monitor. It looks like the below:
Mobile App
Note: The DIYables Bluetooth App supports both BLE and Classic Bluetooth on Android, and BLE on iOS. Since the Arduino Nano 33 IoT uses BLE, the app works on both Android and iOS. No manual pairing is needed for BLE — just scan and connect.
- Open the DIYables Bluetooth App
- When opening the app for the first time, it will ask for permissions. Please grant the following:
- Nearby Devices permission (Android 12+) / Bluetooth permission (iOS) - required to scan and connect to Bluetooth devices
- Location permission (Android 11 and below only) - required by older Android versions to scan for BLE devices
- Make sure Bluetooth is turned on on your phone
- On the home screen, tap the Connect button. The app will scan for BLE devices.

- Find and tap "Arduino_Slider" in the scan results to connect.
- If not found, please update the firmware for the Bluetooth module following this guide on How to Upgrade the Firmware on Arduino Nano 33 IoT
- Once connected, the app automatically goes back to the home screen. Select the Slider app from the app menu.

Note: You can tap the settings icon on the home screen to hide/show apps on the home screen. For more details, see the DIYables Bluetooth App User Manual.
- Drag the sliders to change values

Now look back at the Serial Monitor on Arduino IDE. You will see:
- Adjust the sliders and watch the values change in real time in the Serial Monitor
Creative Customization - Adapt the Code to Your Project
Configure Slider Range
Handle Slider Changes
Send Current Values to App
Handle Connection Events
Programming Examples
LED Brightness Control
Servo Control
Motor Speed with Direction
Advanced Programming Techniques
Slider with Dead Zone
Rate Limiting
Troubleshooting
Common Issues
1. Cannot find the device in the app
- Make sure the Arduino Nano 33 IoT is powered on and the sketch is uploaded
- Ensure your phone's Bluetooth is enabled
- On Android 11 and below, also enable Location services
- Try restarting Bluetooth on your phone
2. Slider changes not received
- Check Bluetooth connection status in the app
- Verify the onSliderValue callback is set up correctly
- Check Serial Monitor for any error messages
3. PWM output not working
- Verify the pin supports PWM on the Nano 33 IoT (pins 2, 3, 5, 6, 9, 10, 11, 12, A5)
- Check wiring connections
- Test with a simple analogWrite sketch first
4. Slider resets to 0 on reconnect
- Implement onGetConfig callback to send stored values on reconnect
- Store slider values in variables that persist across connections
5. Connection drops frequently
- Move closer to the Arduino (reduce distance)
- Check for interference from other BLE devices
- Ensure stable USB power supply
6. Upload fails or board not recognized
- Install the latest Arduino SAMD Boards package via Boards Manager (≥ 1.8.13)
- Try a different USB cable or port
- Press the reset button on the board before uploading
Project Ideas
Lighting Control
- Dual LED brightness controller
- RGB LED color mixer (use two sliders for hue/saturation)
- LED strip brightness and color temperature
- Stage lighting dimmer
Motor Control
- DC motor speed controller
- Dual servo positioning
- Pan-tilt camera mount
- Robot wheel speed
Audio
- Volume control
- Tone frequency and duration
- Equalizer bands
Next Steps
After mastering the Bluetooth Slider example, try:
- Bluetooth Joystick - For 2D directional control
- Bluetooth Rotator - For angular/rotational control
- Bluetooth Temperature - For temperature gauge display
- Multiple Bluetooth Apps - Combining slider with other apps
Support
For additional help:
- Check the API Reference documentation
- Visit DIYables tutorials
- Arduino community forums