- This project is NOT affiliate nor endorsed Live2D Inc, explicitly or implicitly.
- This is a project that helps me learning how to interact with native libraries in Scala/JVM, and how to apply Clean Architecture in a real life scenario. Because such, although the core library of this project is relative fully featured, it should NOT be considered as a replacement for the official Live 2D Cubism SDK.
- As above, this project may be abandoned if I don't interested in this topic any more. Use it at your own risk.
I'm tired that there is no good webcam to Live2D program in Linux. Although the facial-landmarks-for-cubism provides a functional program, it requires user to have some decent knowledge about how to patch and build a C++ program in order to use.
The ultimate goal of this project is to provide something like VTuber Studio in the Linux world. Maybe with less features, but should be with a good out-of-box experience.
The whole idea of this project it that by leverage the Clean Architecture concept proposed by Robert C. Martin (Uncle Bob), combined with it's written in Scala/JVM, it should able to run on both Linux / Windows / MacOS Intel without the change in the source code.
This project is heavily inspired by facial-landmarks-for-cubism. More specifically, the algorithm about how to convert OpenSeeFace data point into Live2D parameter in this project, are ported from facial-landmarks-for-cubism.
The core library support much the same functionality you will find in the official Cubism SDK for Native and the sample application of it.
The following list shows features that this project currently supports or plan to be implemented.
- Motion (Loop or single time)
- Model motion event listener
- Expression
- Physics
- Auto eye-blink
- Auto breath effect
- Face direction control by mouse
- Lip sync from .WAV file in the avatar motion
- Lip sync from microphone
- Use webcam to control Live2D avatar (VTuber like)
Some feature inside Cubism SDK for Native is dropped intended. Because I think these feature are not really useful for create a VTuber program.
The following is the list of such features.
- Priority motion queue
- Control OpenSeeFace -> Live2D model motion parameter through UI.
- Live2D model body movement by face tracking.
Since this project is built on Clean Architecture concept and runs on Java Virtual Machine, it's able to use different Java OpenGL binding API. By default, it provids JavaOpenGL binding and LWJGL + SWT binding.
In theory, it should able to use differnt combination of OpenGL Java libary and GUI toolkit, but the examples come with this project use the following comination.
Due to some weired bug, I couldn't make the example program runs on SWT under MacOS. Also, currently it only support MacOS running on Intel processors, Apple M1 version of MacOS is not supported.
OS / Binding | Architecture | OpenGL Binding | GUI Toolkit | Supported | Note |
---|---|---|---|---|---|
Linux | x86_64 | JavaOpenGL | Swing | ✔️ | |
Linux | x86_64 | LWJGL | SWT | ✔️ | |
Windows 10 | x86_64 | JavaOpenGL | Swing | ✔️ | |
Windows 10 | x86_64 | LWJGL | SWT | ✔️ | |
MacOS | x86_64 | JavaOpenGL | Swing | ✔️ | 1 |
MacOS | x86_64 | LWJGL | SWT | ❌ |
- Must use jogamp-fat-v2.4.0-rc-20210111.jar, auto pull-in dependency from Maven Central will not work.
See doc/INSTALL.md for detailed instruction on how to download the demo application and sample Live 2D model for use.
Both Swing and SWT version of demo application provide same functionality. The following is some basic control scheme.
-
Click
Load Avatar
button on the top-left corner to load Live2D model.1.1 You must select a folder contains a valid
.moc3
file. -
User panel on the left to control effects / motions / expressions.
-
Right click on the avatar and drag to move the avatar around.
-
Use mouse wheel to zoom-in / zoom-out the avatar.
-
Click the
Default Avatar
button to initiate the loading process.When clicked, the application attempts to load the avatar model located in the def_avatar directory, which resides in the same location as the application JAR file.
Since the project follows the Clean Architecture design philosophy, it's seperated into multiple modules. Those modules are SBT sub-projects under the modules
directory.
The following is the overview of this project's structure and breif explanation on each of those modules.
See modules/README.md for detailed documentation of each component and how to use this project's core library in your own project to control Live / render Live2D model.
.
├── build.sbt # SBT build definition
├── doc
├── modules
│ ├── core # The core library to control / render Live2D model.
│ ├── joglBinding # The Java OpenGL binding
│ ├── lwjglBinding # The LWJGL binding
│ ├─── swtBinding # The SWT GLCanvas binding
│ └──── examples
│ ├── base # The base demo application without any GUI toolkit dependency.
│ ├── swing # The full Swing version demo application.
│ ├── swt # The SWT version demo application without SWT runtime.
│ ├── swt-linux-bundle # The SWT version demo application with Linux SWT runtime.
│ └── swt-windows-bundle # The SWT version demo application with Windows SWT runtime.
├── publish.sbt # Maven publish settings
├── release.sbt # Release settings
├── README.md
└── version.sbt # Version settings
- For Windows, download Microsoft Build of OpenJDK and install it.
- For Linux, install it through your distro's package manager.
- For MacOS
- Install Homebrew
- Run
brew install openjdk@11
to install
2. Install SBT (Simple Build Tool)
- Follow the Download page of SBT to install it.
- After SBT is installed, run the following command the clone this project from GitHub.(Taking the upstream project as an example)
username@hostname:~$ git clone https://github.com/brianhsu/Live2DForScala.git
Cloning into 'Live2DForScala'...
remote: Enumerating objects: 10853, done.
remote: Counting objects: 100% (30/30), done.
remote: Compressing objects: 100% (23/23), done.
remote: Total 10853 (delta 6), reused 22 (delta 1), pack-reused 10823
Receiving objects: 100% (10853/10853), 67.14 MiB | 7.30 MiB/s, done.
Resolving deltas: 100% (4483/4483), done.
username@hostname:~$
- Change directory into it and type
sbt
to run SBT console. It may take a while to download files for the first time of execution.
username@hostname:~$ cd Live2DForScala
username@hostname:~/Live2DForScala$ sbt
copying runtime jar...
[info] [launcher] getting org.scala-sbt sbt 1.5.8 (this may take some time)...
:: loading settings :: url = jar:file:/usr/share/sbt-bin/lib/sbt-launch.jar!/org/apache/ivy/core/settings/ivysettings.xml
:: loading settings :: url = jar:file:/usr/share/sbt-bin/lib/sbt-launch.jar!/org/apache/ivy/core/settings/ivysettings.xml
....
[info] welcome to sbt 1.5.8 (Eclipse Adoptium Java 11.0.15)
[info] loading global plugins from /home/brianhsu/.sbt/1.0/plugins
[info] loading settings for project live2dforscala-build from plugins.sbt ...
[info] loading project definition from /home/brianhsu/Live2DForScala/project
[info] loading settings for project core from build.sbt ...
[info] loading settings for project lwjglBinding from build.sbt ...
[info] loading settings for project live2dforscala from build.sbt,publish.sbt,version.sbt ...
[info] set current project to live2dforscala (in build file:/home/brianhsu/Live2DForScala/)
[info] sbt server started at local:///home/brianhsu/.sbt/1.0/server/7f96e432f44ce5ee45c1/sock
[info] started sbt server
sbt:live2dforscala>
- Compile it by typing
compile
in the SBT console.
sbt:live2dforscala> compile
[info] compiling 154 Scala sources and 1 Java source to /home/brianhsu/Live2DForScala/modules/core/target/scala-2.13/classes ...
[info] Non-compiled module 'compiler-bridge_2.13' for Scala 2.13.8. Compiling...
[info] Compilation completed in 4.259s.
[info] compiling 2 Scala sources to /home/brianhsu/Live2DForScala/modules/lwjglBinding/target/scala-2.13/classes ...
[info] compiling 1 Scala source to /home/brianhsu/Live2DForScala/modules/swtBinding/target/scala-2.13/classes ...
[info] compiling 3 Scala sources to /home/brianhsu/Live2DForScala/modules/joglBinding/target/scala-2.13/classes ...
[info] compiling 7 Scala sources to /home/brianhsu/Live2DForScala/modules/examples/base/target/scala-2.13/classes ...
[info] compiling 8 Scala sources to /home/brianhsu/Live2DForScala/modules/examples/swt/target/scala-2.13/classes ...
[info] compiling 8 Scala sources to /home/brianhsu/Live2DForScala/modules/examples/swing/target/scala-2.13/classes ...
sbt:live2dforscala>
- Type
test
in SBT console to run unit test. - Since MacOS does not support SWT+JWJGL, SWTOpenGLCanvasInfoFeature would faild. It's expected.
sbt:live2dforscala> test
[info] compiling 1 Scala source to /home/brianhsu/Live2DForScala/modules/swtBinding/target/scala-2.13/test-classes ...
[info] compiling 1 Scala source to /home/brianhsu/Live2DForScala/modules/lwjglBinding/target/scala-2.13/test-classes ...
[info] compiling 3 Scala sources to /home/brianhsu/Live2DForScala/modules/joglBinding/target/scala-2.13/test-classes ...
[info] Run completed in 326 milliseconds.
[info] Total number of tests run: 2
[info] Suites: completed 1, aborted 0
[info] Tests: succeeded 2, failed 0, canceled 0, ignored 0, pending 0
[info] All tests passed.
[info] SWTOpenGLCanvasInfoFeature:
[info] Feature: Get canvas information
[info] Scenario: Get canvas information from SWT OpenGL Canvas
....
[info] Tests: succeeded 394, failed 0, canceled 0, ignored 0, pending 0
[info] All tests passed.
sbt:live2dforscala>
Type the following command in SBT console to run the demo application.
exampleSwing/run
to run Swing version. Works for Linux / Windows / MacOS.exampleSWTLinux/run
to run SWT version on Linux.exampleSWTWin/run
to run SWT version on Windows.
sbt:live2dforscala> exampleSwing/run
[info] running (fork) moe.brianhsu.live2d.demo.swing.SwingMain
sbt:live2dforscala> exampleSWTLinux/run
[info] running (fork) moe.brianhsu.live2d.demo.swing.SwingMain
Type the following command in SBT console to run the assembly.
exampleSwing/assembly
to assembly Swing version. Works for Linux / Windows / MacOS.exampleSWTLinux/assembly
to assembly SWT version on Linux.exampleSWTWin/assembly
to assembly SWT version on Windows.
sbt:live2dforscala> exampleSWTLinux/assembly
[info] Strategy 'deduplicate' was applied to 5 files (Run the task at debug level to see details)
[info] Strategy 'discard' was applied to 13 files (Run the task at debug level to see details)
[info] Strategy 'rename' was applied to a file (Run the task at debug level to see details)
[info] Assembly up to date: /home/eric/Desktop/codeing/Live2DForScala/modules/examples/swt-linux-bundle/target/scala-2.13/Live2DForScala-SWT-Linux-1.0.2.jar
[warning]Only linux, windows runs need to change the command, but we give a example
Type the following command in SBT console to run the release-tool.
It will collect jar packages, required files and create new executables.
Don't worry about the error.
releaseswing
to run Swing version. Works for Linux / Windows / MacOS.releaselinux
to run SWT version on Linux.releasewin
to run SWT version on Windows.
sbt:live2dforscala> releaselinux
Directory 'release-pkg/Live2DForScala-SWT-Linux-1.0.2' already exists.
[error] stack trace is suppressed; run last moveTasklinux for the full output
[error] stack trace is suppressed; run last createReleasePackageTasklinux for the full output
[error] (moveTasklinux) Failed to copy extra file: exit code
[error] (createReleasePackageTasklinux) Failed to copy openSeeFace directory: exit code
The library and the example program of this project itself is licensed under the MIT license. Please note that this repository also contains files that are belong to other copyright holders, please see the following section for detail. Those files are not considered as "ths project itself" in previous sentence.
You must agree to those license agreement in order to use this program.
This project is based on some 3rd party resources, the following denoted those resources and thier licenses.
This project uses Live2D Cubism Core native library during runtime, it's located at modules/core/src/main/resources/
.
modules/core/src/main/resources/linux-x86-64/libLive2DCubismCore.so
modules/core/src/main/resources/win32-x86-64/Live2DCubismCore.dll
modules/core/src/main/resources/win32-x86-64/Live2DCubismCore.lib
modules/core/src/main/resources/darwin/libLive2DCubismCore.dylib
modules/core/src/main/resources/LICENSE.md
Live2D Cubism Core is available under Live2D Proprietary Software License.
- Live2D Proprietary Software License Agreement
- Live2D Proprietary Software 使用許諾契約書
- Live2D Proprietary Software 使用授权协议
In order to do proper unit test to make sure this project's quality, the Live2D model located at modules/core/src/test/resources/models
are used during unit test. And is included in this project's git repository.
We used it under the Free Material License Agreement from Live2D Inc.
The OpenSeeFace data point to Live2D parameters' algorithm in this project is mainly from adrianiainlam/facial-landmarks-for-cubism.
Although this project does not include the original C++ version source code, it includes comments which could be found at above project regrading the explanation of various calculation.
facial-landmarks-for-cubism is released under MIT License with the following declaration:
Copyright (c) 2020 Adrian I. Lam
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
The released package contains a bundled pre-built OpenSeeFace executable binary, which is released under BSD-2-Clause
license.
The bunlded OpenSeeFace package also contains it's dependencies, namely:
- OpenCV released under Apache License.
- ONNX Runtime released under MIT License.
- Pillow released under Historical Permission Notice and Disclaimer.
- Numpy released under BSD License.
The default background in the example program is licensed under Freepik License by:
The power / gear / speaker icons in the example are licensed under Flaticon License by: