summaryrefslogtreecommitdiff
path: root/src/map_obj_lock.c
diff options
context:
space:
mode:
authorSwastik Baranwal <swstkbaranwal@gmail.com>2019-06-23 18:47:35 +0530
committerGitHub <noreply@github.com>2019-06-23 18:47:35 +0530
commit99703c6ab831d34e6859d8a8f53ba8e73dc4d3d9 (patch)
tree3a712d3039d152616af58a45a13d82c40a87e58f /src/map_obj_lock.c
parent6d190f861e3559eec922cd760778c0cba6e08397 (diff)
parent9ee0c34758a63f8c00724b6fc984b4e96be2f7af (diff)
Merge pull request #5 from pret/master
Take files
Diffstat (limited to 'src/map_obj_lock.c')
-rw-r--r--src/map_obj_lock.c116
1 files changed, 116 insertions, 0 deletions
diff --git a/src/map_obj_lock.c b/src/map_obj_lock.c
new file mode 100644
index 000000000..cdd74a5b9
--- /dev/null
+++ b/src/map_obj_lock.c
@@ -0,0 +1,116 @@
+#include "global.h"
+#include "task.h"
+#include "field_player_avatar.h"
+#include "field_map_obj.h"
+#include "field_map_obj_helpers.h"
+#include "script_movement.h"
+#include "map_obj_80688E4.h"
+#include "event_data.h"
+#include "map_obj_lock.h"
+
+bool8 walkrun_is_standing_still(void)
+{
+ if (gPlayerAvatar.running1 == 1)
+ return FALSE;
+ else
+ return TRUE;
+}
+
+void sub_8069570(u8 taskId)
+{
+ if (walkrun_is_standing_still())
+ {
+ sub_805C270();
+ DestroyTask(taskId);
+ }
+}
+
+bool8 sub_8069590(void)
+{
+ if (FuncIsActiveTask(sub_8069570))
+ return FALSE;
+ else
+ {
+ sub_805C780();
+ return TRUE;
+ }
+}
+
+void ScriptFreezeMapObjects(void)
+{
+ player_bitmagic();
+ CreateTask(sub_8069570, 80);
+}
+
+void sub_80695CC(u8 taskId)
+{
+ struct Task * task = &gTasks[taskId];
+
+ if (task->data[0] == 0 && walkrun_is_standing_still() == TRUE)
+ {
+ sub_805C270();
+ task->data[0] = 1;
+ }
+
+ if (task->data[1] == 0 && !gMapObjects[gSelectedEventObject].mapobj_bit_1)
+ {
+ FreezeMapObject(&gMapObjects[gSelectedEventObject]);
+ task->data[1] = 1;
+ }
+
+ if (task->data[0] && task->data[1])
+ DestroyTask(taskId);
+}
+
+bool8 sub_8069648(void)
+{
+ if (FuncIsActiveTask(sub_80695CC))
+ return FALSE;
+ else
+ {
+ sub_805C780();
+ return TRUE;
+ }
+}
+
+void LockSelectedMapObject(void)
+{
+ u8 taskId;
+
+ FreezeMapObjectsExceptOne(gSelectedEventObject);
+ taskId = CreateTask(sub_80695CC, 80);
+ if (!gMapObjects[gSelectedEventObject].mapobj_bit_1)
+ {
+ FreezeMapObject(&gMapObjects[gSelectedEventObject]);
+ gTasks[taskId].data[1] = 1;
+ }
+}
+
+void sub_80696C0(void)
+{
+ u8 fieldObjectId = GetFieldObjectIdByLocalIdAndMap(0xFF, 0, 0);
+ FieldObjectClearAnimIfSpecialAnimFinished(&gMapObjects[fieldObjectId]);
+ sub_80974D8();
+ UnfreezeMapObjects();
+}
+
+void sub_80696F0(void)
+{
+ u8 fieldObjectId;
+ if (gMapObjects[gSelectedEventObject].active)
+ FieldObjectClearAnimIfSpecialAnimFinished(&gMapObjects[gSelectedEventObject]);
+ fieldObjectId = GetFieldObjectIdByLocalIdAndMap(0xFF, 0, 0);
+ FieldObjectClearAnimIfSpecialAnimFinished(&gMapObjects[fieldObjectId]);
+ sub_80974D8();
+ UnfreezeMapObjects();
+}
+
+void sub_8069740(void)
+{
+ FieldObjectFaceOppositeDirection(&gMapObjects[gSelectedEventObject], gSpecialVar_Facing);
+}
+
+void sub_8069768(void)
+{
+ FieldObjectClearAnimIfSpecialAnimActive(&gMapObjects[gSelectedEventObject]);
+}