User prompt
revert mouth to breath movement when talking is ended
User prompt
revert to breathing behavior after talk
User prompt
mouth increase and decrease multiple time when talking
User prompt
mouth move 3 time faster when talk by increase and decrease multiple time
User prompt
mouth move 3 time more when talking
User prompt
mouth only increase and decrease is size verticaly when talking
User prompt
mouth increase and decrease when talking and talk duration is 5 second
User prompt
The talking duration is 0.5 second more every dialogue leter
User prompt
fix mouth not show
User prompt
fix mouth
User prompt
fix dialogue text
User prompt
Talking duration is base on the dialogue text. Every leter add 0.5 second to the duration
User prompt
when talking the mouth increase and decrese verticaly
User prompt
mouth move 5 time less when talking
User prompt
Fix Bug: 'TypeError: LK.stageContainer.getChildByName is not a function' in this line: 'var girlfriend = LK.stageContainer.getChildByName('VirtualGirlfriend');' Line Number: 72
User prompt
start talking 0.5 second after launch
User prompt
show the dialogue when talking
User prompt
add a dialogue saying hello and spawn dialogue only in talk mode
User prompt
talking make everithing move 10 time more
User prompt
talking make move 5 time more
User prompt
Talking movement are three time faster
User prompt
Make the talk after 1 second
User prompt
the dialogue is empty at launch
User prompt
create a talking behavior who move both the eye and the move like the breathing but three time faster
User prompt
move mouth 10 pixel left and nose 10 pixel left and 10 pixel down
var RightEye = Container.expand(function () {
	var self = Container.call(this);
	var eyeGraphics = self.createAsset('eye', 'Right Eye Graphics', 0.5, 0.5);
	self.addChild(eyeGraphics);
});
var RoomBackground = Container.expand(function () {
	var self = Container.call(this);
	var backgroundGraphics = self.createAsset('roomBackground', 'Room Background', 0.5, 0.5);
	self.addChild(backgroundGraphics);
	backgroundGraphics.width = 2048 * 1.3 * 1.2;
	backgroundGraphics.height = 2732 * 1.2;
	self.x = 2048 / 2;
	self.y = 2732 / 2 - 300;
});
var LeftEye = Container.expand(function () {
	var self = Container.call(this);
	var eyeGraphics = self.createAsset('eye', 'Left Eye Graphics', 0.5, 0.5);
	self.addChild(eyeGraphics);
});
var Nose = Container.expand(function () {
	var self = Container.call(this);
	var noseGraphics = self.createAsset('nose', 'Nose Graphics', 0.5, 0.5);
	self.addChild(noseGraphics);
});
var VirtualGirlfriend = Container.expand(function () {
	var self = Container.call(this);
	var girlfriendGraphics = self.createAsset('girlfriend', 'Virtual Girlfriend', .5, .5);
	self.x = 2048 / 2 - 50;
	self.y = 2732 - girlfriendGraphics.height + 1050;
	self.state = "idle";
	self.dialogue = "Hello!";
	self.breathDuration = 180;
	self.breathCounter = 0;
	self.isBreathingIn = true;
	self.update = function () {
		if (self.isBreathingIn) {
			self.breathCounter++;
			if (self.breathCounter >= self.breathDuration) {
				self.isBreathingIn = false;
			}
		} else {
			self.breathCounter--;
			if (self.breathCounter <= 0) {
				self.isBreathingIn = true;
			}
		}
		var scaleFactor = 1 + self.breathCounter / self.breathDuration * (0.05 / 3);
		this.scale.x = scaleFactor;
		var mouthVerticalScale = 1 + (self.isBreathingIn ? 0.2 : -0.2) * (self.breathCounter / self.breathDuration);
		this.scale.y = scaleFactor;
	};
	self.speak = function () {};
});
var TalkingMouth = Container.expand(function () {
	var self = Container.call(this);
	var mouthGraphics = self.createAsset('mouth', 'Mouth Graphics', 0.5, 0.5);
	self.addChild(mouthGraphics);
	self.talkDuration = 60;
	self.talkCounter = 0;
	self.isTalking = false;
	self.update = function () {
		if (self.isTalking) {
			self.talkCounter++;
			if (self.talkCounter >= self.talkDuration) {
				self.isTalking = false;
				self.talkCounter = 0;
			}
		}
		var talkScale = 1 + (self.isTalking ? 0.2 : -0.2) * (self.talkCounter / self.talkDuration);
		this.scale.y = talkScale;
	};
	self.startTalking = function () {
		self.isTalking = true;
		self.talkCounter = 0;
	};
});
var Game = Container.expand(function () {
	var self = Container.call(this);
	var roomBackground = self.addChild(new RoomBackground());
	roomBackground.x = 2048 / 2;
	roomBackground.y = 2732 / 2;
	var girlfriend = self.addChild(new VirtualGirlfriend());
	var leftEye = self.addChild(new LeftEye());
	var rightEye = self.addChild(new RightEye());
	var nose = self.addChild(new Nose());
	LK.on('tick', function () {
		var breathScale = girlfriend.scale.x;
		leftEye.x = girlfriend.x - 110 * breathScale;
		leftEye.y = girlfriend.y - 200 * breathScale;
		rightEye.x = girlfriend.x + 300 * breathScale;
		rightEye.y = girlfriend.y - 210 * breathScale;
		nose.x = girlfriend.x + 95 * breathScale;
		nose.y = girlfriend.y - 40 * breathScale;
		mouth.x = nose.x;
		mouth.y = nose.y + 220 * breathScale;
	});
	var dialogueTxt = new Text2(girlfriend.dialogue, {
		size: 150,
		fill: "#ffffff"
	});
	var mouth = self.addChild(new TalkingMouth());
	mouth.x = nose.x - 10;
	mouth.y = nose.y + 200;
	dialogueTxt.anchor.set(.5, 0);
	LK.gui.topCenter.addChild(dialogueTxt);
	girlfriend.on('down', function (obj) {
		girlfriend.update();
		mouth.startTalking();
		girlfriend.speak();
		dialogueTxt.setText(girlfriend.dialogue);
	});
	LK.on('tick', function () {
		girlfriend.update();
		mouth.update();
		dialogueTxt.setText(girlfriend.dialogue);
	});
});
 ===================================================================
--- original.js
+++ change.js
@@ -50,12 +50,30 @@
 		this.scale.y = scaleFactor;
 	};
 	self.speak = function () {};
 });
-var Mouth = Container.expand(function () {
+var TalkingMouth = Container.expand(function () {
 	var self = Container.call(this);
 	var mouthGraphics = self.createAsset('mouth', 'Mouth Graphics', 0.5, 0.5);
 	self.addChild(mouthGraphics);
+	self.talkDuration = 60;
+	self.talkCounter = 0;
+	self.isTalking = false;
+	self.update = function () {
+		if (self.isTalking) {
+			self.talkCounter++;
+			if (self.talkCounter >= self.talkDuration) {
+				self.isTalking = false;
+				self.talkCounter = 0;
+			}
+		}
+		var talkScale = 1 + (self.isTalking ? 0.2 : -0.2) * (self.talkCounter / self.talkDuration);
+		this.scale.y = talkScale;
+	};
+	self.startTalking = function () {
+		self.isTalking = true;
+		self.talkCounter = 0;
+	};
 });
 var Game = Container.expand(function () {
 	var self = Container.call(this);
 	var roomBackground = self.addChild(new RoomBackground());
@@ -79,19 +97,21 @@
 	var dialogueTxt = new Text2(girlfriend.dialogue, {
 		size: 150,
 		fill: "#ffffff"
 	});
-	var mouth = self.addChild(new Mouth());
+	var mouth = self.addChild(new TalkingMouth());
 	mouth.x = nose.x - 10;
 	mouth.y = nose.y + 200;
 	dialogueTxt.anchor.set(.5, 0);
 	LK.gui.topCenter.addChild(dialogueTxt);
 	girlfriend.on('down', function (obj) {
 		girlfriend.update();
+		mouth.startTalking();
 		girlfriend.speak();
 		dialogueTxt.setText(girlfriend.dialogue);
 	});
 	LK.on('tick', function () {
 		girlfriend.update();
+		mouth.update();
 		dialogueTxt.setText(girlfriend.dialogue);
 	});
 });
:quality(85)/https://cdn.frvr.ai/6592a82abd75f3a7ac7dfba0.png%3F3) 
 A beautiful woman in a anime style with no eye, no eyebrow and no mouth. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6592ab6fbd75f3a7ac7dfbd4.png%3F3) 
 An eye in a anime style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6592aec6bd75f3a7ac7dfbfc.png%3F3) 
 A beautiful and slim nose in a anime style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6592b1f9bd75f3a7ac7dfc4e.png%3F3) 
 A beautiful women mouth in a manga style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6592bdd2a0750c7c9b32ec0d.png%3F3) 
 A restaurant background in a anime style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6592bed8a0750c7c9b32ec22.png%3F3) 
 A talk button with a buble and a word 'talk'. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.
:quality(85)/https://cdn.frvr.ai/6592c0f1a0750c7c9b32ec3f.png%3F3) 
 A ta dialogue text buble in anime style. Single Game Texture. In-Game asset. 2d. Blank background. High contrast. No shadows.