shaders using wayland time instead of stdtime
This commit is contained in:
parent
bb63b49155
commit
859025a4a3
3 changed files with 14 additions and 31 deletions
29
glonkers.c
29
glonkers.c
|
|
@ -2,7 +2,6 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
#include <time.h>
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <wayland-client.h>
|
#include <wayland-client.h>
|
||||||
#include <wayland-util.h>
|
#include <wayland-util.h>
|
||||||
|
|
@ -12,20 +11,6 @@
|
||||||
#include "wayland.h"
|
#include "wayland.h"
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
struct timespec program_start;
|
|
||||||
|
|
||||||
void init_timer() {
|
|
||||||
clock_gettime(CLOCK_MONOTONIC, &program_start);
|
|
||||||
}
|
|
||||||
|
|
||||||
double time_since_start() {
|
|
||||||
struct timespec now;
|
|
||||||
clock_gettime(CLOCK_MONOTONIC, &now);
|
|
||||||
|
|
||||||
return (now.tv_sec - program_start.tv_sec) +
|
|
||||||
(now.tv_nsec - program_start.tv_nsec) / 1e9;
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char *argv[]) {
|
int main(int argc, char *argv[]) {
|
||||||
char *shader_path = NULL;
|
char *shader_path = NULL;
|
||||||
int output_type = OUTPUT_WINDOW;
|
int output_type = OUTPUT_WINDOW;
|
||||||
|
|
@ -51,27 +36,21 @@ int main(int argc, char *argv[]) {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct client_state state;
|
struct client_state *state = wayland_init(output_type);
|
||||||
wayland_init(&state, output_type);
|
|
||||||
|
|
||||||
Renderer renderer = new_renderer();
|
Renderer renderer = new_renderer();
|
||||||
|
|
||||||
bool running = true;
|
bool running = true;
|
||||||
while (running) {
|
while (running) {
|
||||||
double time = time_since_start();
|
struct event event = wait_for_event(state);
|
||||||
|
|
||||||
struct event event = wait_for_event(&state);
|
|
||||||
if (event.type == EVENT_DRAW) {
|
if (event.type == EVENT_DRAW) {
|
||||||
printf("drawing!!!! %p\n", event.data.draw.surface);
|
|
||||||
int width = event.data.draw.width;
|
int width = event.data.draw.width;
|
||||||
int height = event.data.draw.height;
|
int height = event.data.draw.height;
|
||||||
|
double time = event.data.draw.time / 1000.0;
|
||||||
render(&renderer, width, height, time, shader_path, 0);
|
render(&renderer, width, height, time, shader_path, 0);
|
||||||
printf("about to 🦬 swap buf %p\n", event.data.draw.surface);
|
swap_buffers(state, event.data.draw.surface);
|
||||||
swap_buffers(&state, event.data.draw.surface);
|
|
||||||
printf("🦬🦬🦬 swaped a buffalo\n");
|
|
||||||
}
|
}
|
||||||
if (event.type == EVENT_NONE) {
|
if (event.type == EVENT_NONE) {
|
||||||
printf("nothing, absolutely nothing\n");
|
|
||||||
}
|
}
|
||||||
if (event.type == EVENT_EXIT) {
|
if (event.type == EVENT_EXIT) {
|
||||||
running = false;
|
running = false;
|
||||||
|
|
|
||||||
11
wayland.c
11
wayland.c
|
|
@ -16,6 +16,7 @@ struct surface {
|
||||||
|
|
||||||
/// Wating to be redrawn.
|
/// Wating to be redrawn.
|
||||||
bool dirty;
|
bool dirty;
|
||||||
|
uint32_t time;
|
||||||
|
|
||||||
struct wl_surface *wl_surface;
|
struct wl_surface *wl_surface;
|
||||||
struct xdg_surface *xdg_surface;
|
struct xdg_surface *xdg_surface;
|
||||||
|
|
@ -25,9 +26,6 @@ struct surface {
|
||||||
struct wl_output *wl_output;
|
struct wl_output *wl_output;
|
||||||
|
|
||||||
EGLSurface egl_surface;
|
EGLSurface egl_surface;
|
||||||
|
|
||||||
/// We need a back-pointer for callbacks.
|
|
||||||
struct client_state *state;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct surface_list {
|
struct surface_list {
|
||||||
|
|
@ -156,7 +154,7 @@ static const struct wl_callback_listener wl_surface_frame_listener;
|
||||||
static void
|
static void
|
||||||
wl_surface_frame_done(void *data, struct wl_callback *cb, uint32_t time) {
|
wl_surface_frame_done(void *data, struct wl_callback *cb, uint32_t time) {
|
||||||
struct surface *surface = data;
|
struct surface *surface = data;
|
||||||
struct client_state *state = surface->state;
|
surface->time = time;
|
||||||
|
|
||||||
/* Destroy this callback */
|
/* Destroy this callback */
|
||||||
wl_callback_destroy(cb);
|
wl_callback_destroy(cb);
|
||||||
|
|
@ -455,7 +453,8 @@ static void egl_init(struct client_state *state) {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Initializes wayland and creates an opengl context
|
/// Initializes wayland and creates an opengl context
|
||||||
void wayland_init(struct client_state *state, int output_type) {
|
struct client_state* wayland_init(int output_type) {
|
||||||
|
struct client_state *state = malloc(sizeof(struct client_state));
|
||||||
state->running = 1;
|
state->running = 1;
|
||||||
state->output_type = output_type;
|
state->output_type = output_type;
|
||||||
state->wl_display = wl_display_connect(NULL);
|
state->wl_display = wl_display_connect(NULL);
|
||||||
|
|
@ -474,6 +473,7 @@ void wayland_init(struct client_state *state, int output_type) {
|
||||||
}
|
}
|
||||||
|
|
||||||
egl_init(state);
|
egl_init(state);
|
||||||
|
return state;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct event wait_for_event(struct client_state *state) {
|
struct event wait_for_event(struct client_state *state) {
|
||||||
|
|
@ -507,6 +507,7 @@ struct event wait_for_event(struct client_state *state) {
|
||||||
.draw = {
|
.draw = {
|
||||||
.width = next->data.width,
|
.width = next->data.width,
|
||||||
.height = next->data.height,
|
.height = next->data.height,
|
||||||
|
.time = next->data.time,
|
||||||
.surface = &next->data,
|
.surface = &next->data,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
/// A normal window
|
/// A normal window
|
||||||
#define OUTPUT_WINDOW 0
|
#define OUTPUT_WINDOW 0
|
||||||
/// A desktop layer (wallpaper)
|
/// A desktop layer (wallpaper)
|
||||||
|
|
@ -23,12 +25,13 @@ struct event {
|
||||||
/// EVENT_DRAW
|
/// EVENT_DRAW
|
||||||
struct {
|
struct {
|
||||||
int width, height;
|
int width, height;
|
||||||
|
uint32_t time;
|
||||||
struct surface *surface;
|
struct surface *surface;
|
||||||
} draw;
|
} draw;
|
||||||
} data;
|
} data;
|
||||||
};
|
};
|
||||||
|
|
||||||
void wayland_init(struct client_state *state, int output_type);
|
struct client_state* wayland_init(int output_type);
|
||||||
void commit(struct client_state *state);
|
void commit(struct client_state *state);
|
||||||
struct event wait_for_event(struct client_state *state);
|
struct event wait_for_event(struct client_state *state);
|
||||||
void swap_buffers(struct client_state *state, struct surface *surface);
|
void swap_buffers(struct client_state *state, struct surface *surface);
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue