aboutsummaryrefslogtreecommitdiff
path: root/game/preview/PreviewReplaySubScript.cpp
diff options
context:
space:
mode:
authorheavydemon21 <nielsstunnebrink1@gmail.com>2025-01-10 14:17:38 +0100
committerheavydemon21 <nielsstunnebrink1@gmail.com>2025-01-10 14:17:38 +0100
commit52c838538d2271134a2c5a128074ea9c2ed1d4a3 (patch)
treefd85a4193f88ec48c77d6fbfd90e909ac3a5855c /game/preview/PreviewReplaySubScript.cpp
parent15a958a7f327bb2e81e7d445f1499ec78c7f5839 (diff)
parentbb2db93bfb8dd7e080d2708548eae660e6b33913 (diff)
Merge branch 'master' into niels/game
Diffstat (limited to 'game/preview/PreviewReplaySubScript.cpp')
-rw-r--r--game/preview/PreviewReplaySubScript.cpp56
1 files changed, 56 insertions, 0 deletions
diff --git a/game/preview/PreviewReplaySubScript.cpp b/game/preview/PreviewReplaySubScript.cpp
new file mode 100644
index 0000000..51c27aa
--- /dev/null
+++ b/game/preview/PreviewReplaySubScript.cpp
@@ -0,0 +1,56 @@
+#include "PreviewReplaySubScript.h"
+#include "Config.h"
+#include "menus/ButtonReplaySubScript.h"
+#include <crepe/api/AudioSource.h>
+#include <crepe/types.h>
+
+using namespace crepe;
+using namespace std;
+
+void PreviewReplaySubScript::init() {
+ IButtonScript::init();
+ this->subscribe<ButtonPressEvent>([this](const ButtonPressEvent & e) {
+ return this->on_button_press(e);
+ });
+ this->subscribe<StopPreviewRecording>([this](const StopPreviewRecording & e) {
+ return this->stop_recording();
+ });
+ this->subscribe<DeleteRecordingEvent>([this](const DeleteRecordingEvent & e) {
+ return this->delete_recording();
+ });
+ this->subscribe<StartPreviewRecording>([this](const StartPreviewRecording & e) {
+ return this->start_recording();
+ });
+
+}
+
+bool PreviewReplaySubScript::on_button_press(const ButtonPressEvent & e) {
+ if(DISABLE_REPLAY)return false;
+ replay.play(this->recording);
+ return false;
+}
+bool PreviewReplaySubScript::start_recording(){
+ if(DISABLE_REPLAY)return false;
+ if(record_saved){
+ this->stop_recording();
+ this->delete_recording();
+ }
+ replay.record_start();
+ this->record_started = true;
+ return false;
+}
+
+bool PreviewReplaySubScript::stop_recording() {
+ if(DISABLE_REPLAY)return false;
+ if(this->record_started)this->recording = replay.record_end();
+ this->record_saved = true;
+ return false;
+}
+
+bool PreviewReplaySubScript::delete_recording() {
+ if(DISABLE_REPLAY)return false;
+ if(this->record_started) this->stop_recording();
+ if(this->record_saved)replay.release(this->recording);
+ this->record_saved = false;
+ return false;
+}