summaryrefslogtreecommitdiff
path: root/src/event_obj_lock.c
diff options
context:
space:
mode:
authorMarcus Huderle <huderlem@gmail.com>2018-06-25 17:50:27 -0500
committerMarcus Huderle <huderlem@gmail.com>2018-06-25 17:50:27 -0500
commit605f8ac1141daf66d3428923e004f82f5a5e1594 (patch)
treea3e5fae5d271175c7f10b6b455fcdc7f0fdd553e /src/event_obj_lock.c
parente88e39d5fda1644f77e41fd652d4310612da7532 (diff)
parent659437f07a44b6f560bb58d6c12d141ed8ba7643 (diff)
Merge branch 'master' into contest_link_80C2020
Diffstat (limited to 'src/event_obj_lock.c')
-rw-r--r--src/event_obj_lock.c117
1 files changed, 117 insertions, 0 deletions
diff --git a/src/event_obj_lock.c b/src/event_obj_lock.c
new file mode 100644
index 000000000..33f37e87e
--- /dev/null
+++ b/src/event_obj_lock.c
@@ -0,0 +1,117 @@
+#include "global.h"
+#include "event_obj_lock.h"
+#include "event_object_movement.h"
+#include "field_player_avatar.h"
+#include "script_movement.h"
+#include "task.h"
+
+extern u16 gSpecialVar_Facing;
+
+bool8 walkrun_is_standing_still(void)
+{
+ if (gPlayerAvatar.tileTransitionState == T_TILE_TRANSITION)
+ return FALSE;
+ else
+ return TRUE;
+}
+
+void sub_8064CDC(u8 taskId)
+{
+ if (walkrun_is_standing_still())
+ {
+ sub_80594C0();
+ DestroyTask(taskId);
+ }
+}
+
+bool8 sub_8064CFC(void)
+{
+ if (FuncIsActiveTask(sub_8064CDC))
+ {
+ return FALSE;
+ }
+ else
+ {
+ sub_80597F4();
+ return TRUE;
+ }
+}
+
+void ScriptFreezeEventObjects(void)
+{
+ FreezeEventObjects();
+ CreateTask(sub_8064CDC, 80);
+}
+
+void sub_8064D38(u8 taskId)
+{
+ struct Task *task = &gTasks[taskId];
+
+ if (!task->data[0] && walkrun_is_standing_still() == TRUE)
+ {
+ sub_80594C0();
+ task->data[0] = 1;
+ }
+ if (!task->data[1] && !gEventObjects[gSelectedEventObject].singleMovementActive)
+ {
+ FreezeEventObject(&gEventObjects[gSelectedEventObject]);
+ task->data[1] = 1;
+ }
+ if (task->data[0] && task->data[1])
+ DestroyTask(taskId);
+}
+
+bool8 sub_8064DB4(void)
+{
+ if (FuncIsActiveTask(sub_8064D38))
+ {
+ return FALSE;
+ }
+ else
+ {
+ sub_80597F4();
+ return TRUE;
+ }
+}
+
+void LockSelectedEventObject(void)
+{
+ u8 taskId;
+ FreezeEventObjectsExceptOne(gSelectedEventObject);
+ taskId = CreateTask(sub_8064D38, 80);
+ if (!gEventObjects[gSelectedEventObject].singleMovementActive)
+ {
+ FreezeEventObject(&gEventObjects[gSelectedEventObject]);
+ gTasks[taskId].data[1] = 1;
+ }
+}
+
+void ScriptUnfreezeEventObjects(void)
+{
+ u8 playerObjectId = GetEventObjectIdByLocalIdAndMap(0xFF, 0, 0);
+ EventObjectClearHeldMovementIfFinished(&gEventObjects[playerObjectId]);
+ sub_80A2178();
+ UnfreezeEventObjects();
+}
+
+void unref_sub_8064E5C(void)
+{
+ u8 playerObjectId;
+
+ if (gEventObjects[gSelectedEventObject].active)
+ EventObjectClearHeldMovementIfFinished(&gEventObjects[gSelectedEventObject]);
+ playerObjectId = GetEventObjectIdByLocalIdAndMap(0xFF, 0, 0);
+ EventObjectClearHeldMovementIfFinished(&gEventObjects[playerObjectId]);
+ sub_80A2178();
+ UnfreezeEventObjects();
+}
+
+void sub_8064EAC(void)
+{
+ EventObjectFaceOppositeDirection(&gEventObjects[gSelectedEventObject], gSpecialVar_Facing);
+}
+
+void sub_8064ED4(void)
+{
+ EventObjectClearHeldMovementIfActive(&gEventObjects[gSelectedEventObject]);
+}