summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorXANTRONIX Development2022-03-05 20:33:42 -0500
committerXANTRONIX Development2022-03-05 20:33:42 -0500
commit79886752ce99eab7f6e659aa99f0a416b1928b9d (patch)
treef16440b3b2aba9de5c79b37464ed995a9197c1a1 /src
parent2894d2f9e4e2a646116836aa2b471c33fbba85f5 (diff)
downloadxas-79886752ce99eab7f6e659aa99f0a416b1928b9d.tar.gz
xas-79886752ce99eab7f6e659aa99f0a416b1928b9d.tar.bz2
xas-79886752ce99eab7f6e659aa99f0a416b1928b9d.zip
Add heading, speed event events to spatial objects
Diffstat (limited to 'src')
-rw-r--r--src/seq.c60
1 files changed, 60 insertions, 0 deletions
diff --git a/src/seq.c b/src/seq.c
index 64b3544..ba9046c 100644
--- a/src/seq.c
+++ b/src/seq.c
@@ -139,6 +139,56 @@ error_malloc_ev:
return -1;
}
+int xas_seq_add_set_heading(xas_seq *seq,
+ xas_spatial_object *object,
+ struct timeval timestamp,
+ xas_spatial_coord heading) {
+ xas_seq_event *ev;
+
+ if ((ev = malloc(sizeof(*ev))) == NULL) {
+ goto error_malloc_ev;
+ }
+
+ ev->type = XAS_SEQ_EVENT_SET_HEADING;
+ ev->objtype = XAS_SEQ_OBJECT_ANY;
+ ev->object = object;
+ ev->timestamp = timestamp;
+ ev->heading = heading;
+ ev->next = NULL;
+
+ add_event(seq, ev);
+
+ return 0;
+
+error_malloc_ev:
+ return -1;
+}
+
+int xas_seq_add_set_speed(xas_seq *seq,
+ xas_spatial_object *object,
+ struct timeval timestamp,
+ float speed) {
+ xas_seq_event *ev;
+
+ if ((ev = malloc(sizeof(*ev))) == NULL) {
+ goto error_malloc_ev;
+ }
+
+ ev->type = XAS_SEQ_EVENT_SET_SPEED;
+ ev->objtype = XAS_SEQ_OBJECT_ANY;
+ ev->object = object;
+ ev->timestamp = timestamp;
+ ev->speed = speed;
+ ev->next = NULL;
+
+ add_event(seq, ev);
+
+ return 0;
+
+error_malloc_ev:
+ return -1;
+}
+
int xas_seq_add_set_gain(xas_seq *seq,
xas_spatial_object *object,
struct timeval timestamp,
@@ -254,6 +304,16 @@ static int event_trigger(xas_spatial_scene *scene, xas_seq_event *ev) {
break;
+ case XAS_SEQ_EVENT_SET_HEADING:
+ ev->object->heading = ev->heading;
+
+ break;
+
+ case XAS_SEQ_EVENT_SET_SPEED:
+ ev->object->speed = ev->speed;
+
+ break;
+
case XAS_SEQ_EVENT_SET_GAIN:
xas_object_set_gain(ev->object->ctx, ev->gain);