3#include "../Templates/ProtogenProjectTemplate.h"
4#include "../../Assets/Models/OBJ/Background.h"
5#include "../../Assets/Models/FBX/Commissions/AceFace.h"
6#include "../../Assets/Models/FBX/Commissions/AceCrash.h"
7#include "../../Assets/Models/FBX/Commissions/AceCrashBackground.h"
8#include "../../Scene/Materials/Utils/MaterialAnimator.h"
10#include "../../Camera/CameraManager/Implementations/WS35SplitCameras.h"
11#include "../../Controller/WS35Controller.h"
29 const __FlashStringHelper*
faceArray[12] = {F(
"DEFAULT"), F(
"SMIRK"), F(
"CONTENT"), F(
"SRPRISE"), F(
"SRSLY"), F(
"ANGRY"), F(
"SCRUNCHY"), F(
"HAPPY"), F(
"CRASH"), F(
"AUDIO1"), F(
"AUDIO2"), F(
"AUDIO3")};
33 AddParameter(AceFace::Blush,
pM.GetMorphWeightReference(AceFace::Blush), 35);
34 AddParameter(AceFace::Content,
pM.GetMorphWeightReference(AceFace::Content), 40);
35 AddParameter(AceFace::Surprised,
pM.GetMorphWeightReference(AceFace::Surprised), 15);
36 AddParameter(AceFace::Seriously,
pM.GetMorphWeightReference(AceFace::Seriously), 30);
37 AddParameter(AceFace::Angry,
pM.GetMorphWeightReference(AceFace::Angry), 20);
38 AddParameter(AceFace::Scrunchy,
pM.GetMorphWeightReference(AceFace::Scrunchy), 35);
39 AddParameter(AceFace::Happy,
pM.GetMorphWeightReference(AceFace::Happy), 45);
134 else if (mode == 1)
Smirk();
138 else if (mode == 5)
Angry();
140 else if (mode == 7)
Happy();
141 else if (mode == 8)
Crash();
142 else if (mode == 9) {
145 else if (mode == 10){
155 pM.SetMorphWeight(AceFace::MoveNose, 1.0f);
175 pM.GetObject()->UpdateTransform();
179 crash.GetObject()->UpdateTransform();
WS35Controller controller
void LinkControlParameters() override
Links external or user-defined control parameters (pure virtual to be implemented).
SimpleMaterial blackMaterial
WS35SplitCameraManager cameras
AceCrashBackground crashBackground
MaterialAnimator< 2 > crashBackgroundMaterial
void Update(float ratio) override
Updates the project state based on the given ratio.
const __FlashStringHelper * faceArray[12]
SimpleMaterial whiteMaterial
SimpleMaterial lBlueMaterial
MaterialAnimator< 2 > crashMaterial
void SetFaceArray(const __FlashStringHelper **faceNames)
Sets the array of face names.
@ Cosine
Smooth cosine interpolation.
Animates transitions and blends between multiple materials.
void AddMaterial(Material::Method method, Material *material, uint16_t frames, float minOpacity, float maxOpacity)
Adds a material to the animation with specified properties.
void SetBaseMaterial(Material::Method method, Material *material)
Sets the base material for the animation.
float GetMaterialOpacity(Material &material)
Retrieves the current opacity of a material.
void AddMaterialFrame(Material &material, float opacity)
Adds a specific frame for a material in the animation.
void Update()
Updates the animator, advancing the transitions.
@ Add
Adds colors together.
@ Replace
Replaces the base color.
Represents a 3D object with geometry, material, and transformation data.
Scene scene
The Scene object representing the rendered environment.
A default project template that includes functionality for an analog microphone, APDS9960 boop sensor...
void SetMenuWiggleSpeed(float multiplierX, float multiplierY, float multiplierR)
Adjusts the menu's wiggle speed along X, Y, and rotation.
Vector3D GetWiggleOffset()
Computes and returns a Vector3D offset for a "wiggle" effect using function generators.
void EnableBlinking()
Enables blinking (resets and plays the blink track).
void AudioReactiveGradientFace()
Enables the Audio Reactive Gradient on the face, updating offsets and calling callbacks.
void SetMenuOffset(Vector2D offset)
Sets the menu's position offset.
void SetMenuSize(Vector2D size)
Sets the menu's size.
void OscilloscopeFace()
Enables the Oscilloscope on the face, updating offsets and calling callbacks.
void UpdateFace(float ratio)
Updates the face's rendered content, reading any user input and applying changes.
void SetWiggleSpeed(float multiplier)
Sets the overall wiggle speed for both X and Y function generators.
bool IsBooped()
Checks if the sensor has detected a boop.
void SpectrumAnalyzerFace()
Enables the Spectrum Analyzer on the face, updating offsets and calling callbacks.
void AddParameter(uint8_t index, float *parameter, uint16_t transitionFrames, IEasyEaseAnimator::InterpolationMethod interpolationMethod=IEasyEaseAnimator::InterpolationMethod::Overshoot, bool invertDirection=false)
Adds a parameter to the EasyEaseAnimator for interpolation.
void DisableBlinking()
Disables blinking (pauses and resets the blink track).
void AlignObjectFace(Object3D *obj, float rotation=0.0f, float margin=2.0f, bool mirror=true)
Aligns a single Object3D to the "face" camera bounds with scaling.
void AlignObjectsNoScale(Vector2D min, Vector2D max, Object3D **objects, uint8_t objectCount, float rotation=0.0f, float margin=2.0f, bool mirror=true)
Aligns multiple Object3D objects without scaling.
void AddViseme(Viseme::MouthShape visemeName, float *parameter)
Adds a viseme parameter to the animator (for mouth shapes).
@ CRAINBOW
Rainbow spiral.
HeadsUpDisplay hud
Heads-up display (HUD) for the face overlay or additional data.
void AddMaterialFrame(Color color, float opacity=0.8f)
Adds a new material frame to the face's MaterialAnimator from a color enum.
void HideFace()
Hides the face by setting its offset parameter.
void AddBlinkParameter(float *blinkParameter)
Adds a float parameter to the blink track for controlling blinking.
void AddParameterFrame(uint16_t ProjectIndex, float target)
Adds a frame target to a previously added parameter.
Material * GetFaceMaterial()
Retrieves the current face material animator.
Represents an RGB color and provides methods for manipulation.
void AddObject(Object3D *object)
Adds a 3D object to the scene.
A material that applies a single, solid RGB color to surfaces.
Represents a 2D vector (X, Y) and provides methods for vector arithmetic.
Represents a 3D vector (X, Y, Z) and provides methods for vector arithmetic.
@ ER
Mouth shape corresponding to the "ER" sound.
@ OO
Mouth shape corresponding to the "OO" sound.
@ AH
Mouth shape corresponding to the "AH" sound.
@ UH
Mouth shape corresponding to the "UH" sound.
@ AR
Mouth shape corresponding to the "AR" sound.
@ SS
Mouth shape corresponding to the "SS" sound (optional).
@ EE
Mouth shape corresponding to the "EE" sound.
Manages WS2812-based displays for the Delta, Epsilon, and Sigma Protogen heads.
void SetAccentBrightness(uint8_t maxAccentBrightness) override
Sets the maximum accent brightness (not used for this controller).
void SetBrightness(uint8_t maxBrightness) override
Sets the maximum brightness for the displays.