Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/meganetaaan/m5stack-avatar
An M5Stack library for rendering avatar faces
https://github.com/meganetaaan/m5stack-avatar
arduino esp32 m5stack
Last synced: 3 months ago
JSON representation
An M5Stack library for rendering avatar faces
- Host: GitHub
- URL: https://github.com/meganetaaan/m5stack-avatar
- Owner: meganetaaan
- License: mit
- Created: 2018-04-04T00:56:04.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-06-02T05:19:03.000Z (6 months ago)
- Last Synced: 2024-06-25T09:42:38.068Z (5 months ago)
- Topics: arduino, esp32, m5stack
- Language: C++
- Homepage:
- Size: 1.16 MB
- Stars: 165
- Watchers: 15
- Forks: 28
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-social-robots - M5Stack Avatar - avatar) | Shinya Ishikawa | ([Libraries](#libraries))
README
# M5Stack-Avatar
[![Powered By PlatformIO](https://img.shields.io/badge/powered-PlatformIO-brightgreen)](https://platformio.org/)
[![Build Status](https://travis-ci.com/meganetaaan/m5stack-avatar.svg?branch=master)](https://travis-ci.com/meganetaaan/m5stack-avatar)![M5Stack-Avatar](docs/image/avatar.gif)
Video: https://www.youtube.com/watch?v=C1Hj9kfY5qc
[日本語](README_ja.md)
## Features
* :neutral_face: Draw avatar face
* :smile: Expression(Happy, Angry, Sad etc.)
* :smiley_cat: Customize face
* :kiss: Lip sync
* :art: Color Palette
* :arrows_clockwise: Move, Zoom and Rotation
* :two: Compatible with M5Stack Core2## Installation
### Prerequisites
* USB Driver is installed throwgh [Getting Started: Installing the USB Driver](http://www.m5stack.com/assets/docs/)
* Any of IDE is set up
* This library is confirmed on __Arduino IDE__ and __Platform IO__ for now### Using Arduino IDE
* On Arduino IDE, Select "Sketch > Include Library > Manage Libraries..."
* Search "m5stack avatar"
* Select "M5Stack_Avatar" from the results then click "Install"
* The library gets installed### Using Platform IO
* Initialize your Platform IO project
```sh
mkdir my-avatar
cd my-avatar
platformio init -d . -b m5stack-core-esp32
```
* Install the library and its dependency
```sh
platformio lib install M5Unified
platformio lib install M5Stack-Avatar
```
* The library gets downloaded from repository to .piolibdeps directory## Usage
```cpp
#include
#includeusing namespace m5avatar;
Avatar avatar;
void setup()
{
M5.begin();
avatar.init(); // start drawing
}void loop()
{
// avatar's face updates in another thread
// so no need to loop-by-loop rendering
}
```### Using LipSync
* setup AquesTalk-ESP32 (http://blog-yama.a-quest.com/?eid=970195).
* (For parsing Kainji statement) Copy the dictionary file from above link to the microSD card.
* You don't need to copy AquesTalkTTS files. They are included in this library.* Write below to open avatar mouth according to the audio output.
```cpp
#include
#include
#include
#includeusing namespace m5avatar;
// AquesTalk License Key
// NULL or wrong value is just ignored
const char* AQUESTALK_KEY = "XXXX-XXXX-XXXX-XXXX";
Avatar avatar;void setup() {
int iret;
M5.begin();
// For Kanji-to-speech mode (requires dictionary file saved on microSD)
// iret = TTS.createK(AQUESTALK_KEY);
iret = TTS.create(AQUESTALK_KEY);
avatar.init();
avatar.addTask(lipSync, "lipSync");
}void loop() {
M5.update();
if (M5.BtnA.wasPressed()) {
// For Kanji-to-speech mode
// TTS.play("こんにちは。", 80);
TTS.play("konnichiwa", 80);
}
}```
### Further usage
see `examples` directory.
### Migration from 0.7.x to 0.8.x
`M5Stack-Avatar` now depends on `M5Unified`, the integrated library for all devices of M5Stack series.
Since 0.8.0, Sketches with avatar should include `M5Unified.h` instead of `M5Stack.h` or `M5Core2.h`