From a9e1130244421fb3dbcc369a9cb96050a9835100 Mon Sep 17 00:00:00 2001 From: Rui Matos Date: Mon, 11 Apr 2016 16:25:37 +0200 Subject: [PATCH] drop examples --- Makefile.am | 2 +- configure.ac | 12 - examples/Makefile.am | 102 -- examples/android/hello/.gitignore | 7 - examples/android/hello/AndroidManifest.xml | 30 - examples/android/hello/build.xml | 84 -- examples/android/hello/jni/Android.mk | 19 - examples/android/hello/jni/Application.mk | 1 - examples/android/hello/jni/main.c | 188 --- examples/android/hello/res/values/strings.xml | 4 - examples/cogl-basic-video-player.c | 422 ------ examples/cogl-crate.c | 300 ---- examples/cogl-emscripten-hello.c | 149 -- examples/cogl-gjs.js | 46 - examples/cogl-gles2-context.c | 138 -- examples/cogl-gles2-gears.c | 825 ----------- examples/cogl-hello.c | 123 -- examples/cogl-info.c | 250 ---- examples/cogl-msaa.c | 114 -- examples/cogl-point-sprites.c | 323 ----- examples/cogl-stereo.c | 152 -- examples/cogl-x11-foreign.c | 203 --- examples/cogl-x11-tfp.c | 408 ------ examples/cogland.c | 1224 ----------------- examples/crate.jpg | Bin 171588 -> 0 bytes examples/emscripten-example-js-library.js | 19 - examples/emscripten-example-js.h | 18 - 27 files changed, 1 insertion(+), 5162 deletions(-) delete mode 100644 examples/Makefile.am delete mode 100644 examples/android/hello/.gitignore delete mode 100644 examples/android/hello/AndroidManifest.xml delete mode 100644 examples/android/hello/build.xml delete mode 100644 examples/android/hello/jni/Android.mk delete mode 100644 examples/android/hello/jni/Application.mk delete mode 100644 examples/android/hello/jni/main.c delete mode 100644 examples/android/hello/res/values/strings.xml delete mode 100644 examples/cogl-basic-video-player.c delete mode 100644 examples/cogl-crate.c delete mode 100644 examples/cogl-emscripten-hello.c delete mode 100644 examples/cogl-gjs.js delete mode 100644 examples/cogl-gles2-context.c delete mode 100644 examples/cogl-gles2-gears.c delete mode 100644 examples/cogl-hello.c delete mode 100644 examples/cogl-info.c delete mode 100644 examples/cogl-msaa.c delete mode 100644 examples/cogl-point-sprites.c delete mode 100644 examples/cogl-stereo.c delete mode 100644 examples/cogl-x11-foreign.c delete mode 100644 examples/cogl-x11-tfp.c delete mode 100644 examples/cogland.c delete mode 100644 examples/crate.jpg delete mode 100644 examples/emscripten-example-js-library.js delete mode 100644 examples/emscripten-example-js.h diff --git a/Makefile.am b/Makefile.am index ddad1a0f5..46cb27994 100644 --- a/Makefile.am +++ b/Makefile.am @@ -14,7 +14,7 @@ if BUILD_COGL_GLES2 SUBDIRS += cogl-gles2 endif -SUBDIRS += tests examples po +SUBDIRS += tests po ACLOCAL_AMFLAGS = -I build/autotools ${ACLOCAL_FLAGS} diff --git a/configure.ac b/configure.ac index 9d4492d78..36b7936ec 100644 --- a/configure.ac +++ b/configure.ac @@ -502,17 +502,6 @@ AS_IF( ] ) -dnl ============================================================ -dnl Should examples be installed? -dnl ============================================================ -AC_ARG_ENABLE( - [examples-install], - [AC_HELP_STRING([--enable-examples-install=@<:@no/yes@:>@], [Enable installation of examples @<:@default=no@:>@])], - [], - enable_examples_install=no -) -AM_CONDITIONAL([INSTALL_EXAMPLES], [test "x$enable_examples_install" = "xyes"]) - dnl ============================================================ dnl Determine which drivers and window systems we can support dnl ============================================================ @@ -1091,7 +1080,6 @@ cogl-path/cogl-path-2.0-experimental.pc cogl-gles2/Makefile cogl-gles2/cogl-gles2-1.0.pc cogl-gles2/cogl-gles2-2.0-experimental.pc -examples/Makefile tests/Makefile tests/config.env tests/conform/Makefile diff --git a/examples/Makefile.am b/examples/Makefile.am deleted file mode 100644 index 30b30a4a2..000000000 --- a/examples/Makefile.am +++ /dev/null @@ -1,102 +0,0 @@ -include $(top_srcdir)/build/autotools/Makefile.am.silent - -AM_CPPFLAGS = \ - -I$(top_srcdir) - -if !USE_GLIB -AM_CPPFLAGS += -I$(top_builddir)/deps/glib -endif - -AM_CFLAGS = \ - $(COGL_DEP_CFLAGS) \ - $(COGL_EXTRA_CFLAGS) \ - -DCOGL_ENABLE_EXPERIMENTAL_2_0_API - -if INSTALL_EXAMPLES -AM_CFLAGS += -DCOGL_EXAMPLES_DATA=\""$(pkgdatadir)/examples-data/"\" -else -AM_CFLAGS += -DCOGL_EXAMPLES_DATA=\""$(abs_top_srcdir)/examples/"\" -endif - -common_ldadd = \ - $(COGL_DEP_LIBS) \ - $(top_builddir)/cogl/libcogl.la \ - $(LIBM) - -if !USE_GLIB -common_ldadd += $(top_builddir)/deps/glib/libglib.la -endif - -programs = cogl-info - -cogl_info_SOURCES = cogl-info.c -cogl_info_LDADD = $(common_ldadd) - -if USE_GLIB -programs += cogl-hello cogl-msaa cogl-gles2-context cogl-point-sprites cogl-stereo -examples_datadir = $(pkgdatadir)/examples-data -examples_data_DATA = - -cogl_hello_SOURCES = cogl-hello.c -cogl_hello_LDADD = $(common_ldadd) -cogl_msaa_SOURCES = cogl-msaa.c -cogl_msaa_LDADD = $(common_ldadd) -cogl_point_sprites_SOURCES = cogl-point-sprites.c -cogl_point_sprites_LDADD = $(common_ldadd) -cogl_stereo_SOURCES = cogl-stereo.c -cogl_stereo_LDADD = $(common_ldadd) - -if BUILD_COGL_PANGO -programs += cogl-crate -cogl_crate_SOURCES = cogl-crate.c -cogl_crate_LDADD = $(common_ldadd) $(COGL_PANGO_DEP_LIBS) $(top_builddir)/cogl-pango/libcogl-pango.la -cogl_crate_CFLAGS = $(AM_CFLAGS) $(COGL_PANGO_DEP_CFLAGS) -examples_data_DATA += crate.jpg -endif - -if X11_TESTS -programs += cogl-x11-foreign cogl-x11-tfp -cogl_x11_foreign_SOURCES = cogl-x11-foreign.c -cogl_x11_foreign_LDADD = $(common_ldadd) -cogl_x11_tfp_SOURCES = cogl-x11-tfp.c -cogl_x11_tfp_LDADD = $(common_ldadd) -endif - -if SUPPORT_WAYLAND_EGL_SERVER -# Note: Cogland currently only builds for Wayland 0.85 -programs += cogland -cogland_SOURCES = cogland.c -cogland_LDADD = $(common_ldadd) -endif - -cogl_gles2_context_SOURCES = cogl-gles2-context.c -cogl_gles2_context_LDADD = $(common_ldadd) - -if BUILD_COGL_GLES2 -programs += cogl-gles2-gears -cogl_gles2_gears_SOURCES = cogl-gles2-gears.c -cogl_gles2_gears_CFLAGS = -I$(top_srcdir)/cogl-gles2 $(AM_CFLAGS) -cogl_gles2_gears_LDADD = $(common_ldadd) $(top_builddir)/cogl-gles2/libcogl-gles2.la -endif - -endif #USE_GLIB - -if INSTALL_EXAMPLES -bin_PROGRAMS = $(programs) -else -noinst_PROGRAMS = $(programs) -endif - -EXTRA_DIST = \ - cogl-gjs.js \ - crate.jpg \ - emscripten-example-js.h \ - emscripten-example-js-library.js \ - android/hello/AndroidManifest.xml \ - android/hello/jni/Application.mk \ - android/hello/jni/Android.mk \ - android/hello/jni/main.c \ - android/hello/res/values/strings.xml \ - android/hello/.gitignore \ - android/hello/build.xml - diff --git a/examples/android/hello/.gitignore b/examples/android/hello/.gitignore deleted file mode 100644 index 7fdabdd44..000000000 --- a/examples/android/hello/.gitignore +++ /dev/null @@ -1,7 +0,0 @@ -bin -libs -obj - -default.properties -local.properties -proguard.cfg diff --git a/examples/android/hello/AndroidManifest.xml b/examples/android/hello/AndroidManifest.xml deleted file mode 100644 index 3cb6026fb..000000000 --- a/examples/android/hello/AndroidManifest.xml +++ /dev/null @@ -1,30 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - diff --git a/examples/android/hello/build.xml b/examples/android/hello/build.xml deleted file mode 100644 index d69afbc37..000000000 --- a/examples/android/hello/build.xml +++ /dev/null @@ -1,84 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/examples/android/hello/jni/Android.mk b/examples/android/hello/jni/Android.mk deleted file mode 100644 index 01c811cfe..000000000 --- a/examples/android/hello/jni/Android.mk +++ /dev/null @@ -1,19 +0,0 @@ -LOCAL_PATH := $(call my-dir) - -include $(CLEAR_VARS) - -LOCAL_MODULE := test-cogl-hello -LOCAL_SRC_FILES := main.c -LOCAL_LDLIBS := -llog -landroid -lEGL -lGLESv1_CM -LOCAL_STATIC_LIBRARIES := cogl android_native_app_glue gobject gmodule gthread glib-android glib iconv -LOCAL_ARM_MODE := arm -LOCAL_CFLAGS := \ - -DG_LOG_DOMAIN=\"TestCoglHello\" \ - -DCOGL_ENABLE_EXPERIMENTAL_2_0_API \ - $(NULL) - -include $(BUILD_SHARED_LIBRARY) - -$(call import-module,android/native_app_glue) -$(call import-module,glib) -$(call import-module,cogl) diff --git a/examples/android/hello/jni/Application.mk b/examples/android/hello/jni/Application.mk deleted file mode 100644 index 22d188e59..000000000 --- a/examples/android/hello/jni/Application.mk +++ /dev/null @@ -1 +0,0 @@ -APP_PLATFORM := android-9 diff --git a/examples/android/hello/jni/main.c b/examples/android/hello/jni/main.c deleted file mode 100644 index c9a84018c..000000000 --- a/examples/android/hello/jni/main.c +++ /dev/null @@ -1,188 +0,0 @@ -/* - * Copyright (C) 2010 The Android Open Source Project - * Copyright (C) 2011 Intel Corporation - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - * - */ - -/* - * This file is derived from the "native-activity" sample of the android NDK - * r5b. The coding style has been adapted to the code style most commonly found - * in glib/gobject based projects. - */ - -#include - -#include -#include -#include - -typedef struct -{ - struct android_app* app; - - CoglContext *context; - CoglPrimitive *triangle; - CoglFramebuffer *fb; -} TestData; - -static int test_init (TestData* data) -{ - CoglOnscreen *onscreen; - CoglError *error = NULL; - CoglVertexP2C4 triangle_vertices[] = { - {0, 0.7, 0xff, 0x00, 0x00, 0xff}, - {-0.7, -0.7, 0x00, 0xff, 0x00, 0xff}, - {0.7, -0.7, 0x00, 0x00, 0xff, 0xff} - }; - - cogl_android_set_native_window (data->app->window); - - data->context = cogl_context_new (NULL, &error); - if (!data->context) - { - g_critical ("Failed to create context: %s\n", error->message); - return 1; - } - - onscreen = cogl_onscreen_new (data->context, 320, 420); - - /* Eventually there will be an implicit allocate on first use so this - * will become optional... */ - data->fb = COGL_FRAMEBUFFER (onscreen); - if (!cogl_framebuffer_allocate (data->fb, &error)) - { - if (error) - g_critical ("Failed to allocate framebuffer: %s\n", error->message); - else - g_critical ("Failed to allocate framebuffer"); - return 1; - } - - cogl_onscreen_show (onscreen); - - cogl_push_framebuffer (data->fb); - - data->triangle = cogl_primitive_new_p2c4 (COGL_VERTICES_MODE_TRIANGLES, - 3, triangle_vertices); - - return 0; -} - -static test_draw_frame_and_swap (TestData *data) -{ - if (data->context) - { - cogl_primitive_draw (data->triangle); - cogl_framebuffer_swap_buffers (data->fb); - } -} - -static void -test_fini (TestData *data) -{ - if (data->fb) - { - cogl_object_unref (data->triangle); - cogl_object_unref (data->fb); - cogl_object_unref (data->context); - data->triangle = NULL; - data->fb = NULL; - data->context = NULL; - } -} - -/** - * Process the next main command. - */ -static void -test_handle_cmd (struct android_app* app, - int32_t cmd) -{ - TestData *data = (TestData *) app->userData; - - switch (cmd) - { - case APP_CMD_INIT_WINDOW: - /* The window is being shown, get it ready */ - g_message ("command: INIT_WINDOW"); - if (data->app->window != NULL) - { - test_init (data); - test_draw_frame_and_swap (data); - } - break; - - case APP_CMD_TERM_WINDOW: - /* The window is being hidden or closed, clean it up */ - g_message ("command: TERM_WINDOW"); - test_fini (data); - break; - - case APP_CMD_GAINED_FOCUS: - g_message ("command: GAINED_FOCUS"); - break; - - case APP_CMD_LOST_FOCUS: - /* When our app loses focus, we stop monitoring the accelerometer. - * This is to avoid consuming battery while not being used. */ - g_message ("command: LOST_FOCUS"); - test_draw_frame_and_swap (data); - break; - } -} - -/** - * This is the main entry point of a native application that is using - * android_native_app_glue. It runs in its own thread, with its own - * event loop for receiving input events and doing other things. - */ -void -android_main (struct android_app* application) -{ - TestData data; - - /* Make sure glue isn't stripped */ - app_dummy (); - - g_android_init (); - - memset (&data, 0, sizeof (TestData)); - application->userData = &data; - application->onAppCmd = test_handle_cmd; - data.app = application; - - while (1) - { - int events; - struct android_poll_source* source; - - while ((ALooper_pollAll (0, NULL, &events, (void**)&source)) >= 0) - { - - /* Process this event */ - if (source != NULL) - source->process (application, source); - - /* Check if we are exiting */ - if (application->destroyRequested != 0) - { - test_fini (&data); - return; - } - } - - test_draw_frame_and_swap (&data); - } -} diff --git a/examples/android/hello/res/values/strings.xml b/examples/android/hello/res/values/strings.xml deleted file mode 100644 index e4cdec035..000000000 --- a/examples/android/hello/res/values/strings.xml +++ /dev/null @@ -1,4 +0,0 @@ - - - TestCoglHello - diff --git a/examples/cogl-basic-video-player.c b/examples/cogl-basic-video-player.c deleted file mode 100644 index f894c38de..000000000 --- a/examples/cogl-basic-video-player.c +++ /dev/null @@ -1,422 +0,0 @@ -#include -#include -#include - -#include -#include - -typedef struct _Data -{ - CoglFramebuffer *fb; - CoglPipeline *border_pipeline; - CoglPipeline *video_pipeline; - CoglGstVideoSink *sink; - int onscreen_width; - int onscreen_height; - CoglGstRectangle video_output; - bool draw_ready; - bool frame_ready; - GMainLoop *main_loop; -}Data; - -static gboolean -_bus_watch (GstBus *bus, - GstMessage *msg, - void *user_data) -{ - Data *data = (Data*) user_data; - switch (GST_MESSAGE_TYPE (msg)) - { - case GST_MESSAGE_EOS: - { - g_main_loop_quit (data->main_loop); - break; - } - case GST_MESSAGE_ERROR: - { - char *debug; - GError *error = NULL; - - gst_message_parse_error (msg, &error, &debug); - g_free (debug); - - if (error != NULL) - { - g_error ("Playback error: %s\n", error->message); - g_error_free (error); - } - g_main_loop_quit (data->main_loop); - break; - } - default: - break; - } - - return TRUE; -} - -static void -_draw (Data *data) -{ - /* - The cogl pipeline needs to be retrieved from the sink before every draw. - This is due to the cogl-gst sink creating a new cogl pipeline for each frame - by copying the previous one and attaching the new frame to it. - */ - CoglPipeline* current = cogl_gst_video_sink_get_pipeline (data->sink); - - data->video_pipeline = current; - - if (data->video_output.x) - { - int x = data->video_output.x; - - /* Letterboxed with vertical borders */ - cogl_framebuffer_draw_rectangle (data->fb, - data->border_pipeline, - 0, 0, x, data->onscreen_height); - cogl_framebuffer_draw_rectangle (data->fb, - data->border_pipeline, - data->onscreen_width - x, - 0, - data->onscreen_width, - data->onscreen_height); - cogl_framebuffer_draw_rectangle (data->fb, data->video_pipeline, - x, 0, - x + data->video_output.width, - data->onscreen_height); - } - else if (data->video_output.y) - { - int y = data->video_output.y; - - /* Letterboxed with horizontal borders */ - cogl_framebuffer_draw_rectangle (data->fb, - data->border_pipeline, - 0, 0, data->onscreen_width, y); - cogl_framebuffer_draw_rectangle (data->fb, - data->border_pipeline, - 0, - data->onscreen_height - y, - data->onscreen_width, - data->onscreen_height); - cogl_framebuffer_draw_rectangle (data->fb, data->video_pipeline, - 0, y, - data->onscreen_width, - y + data->video_output.height); - - } - else - { - cogl_framebuffer_draw_rectangle (data->fb, - data->video_pipeline, - 0, 0, - data->onscreen_width, - data->onscreen_height); - } - - cogl_onscreen_swap_buffers (COGL_ONSCREEN (data->fb)); -} - -static void -_check_draw (Data *data) -{ - /* The frame is only drawn once we know that a new buffer is ready - * from GStreamer and that Cogl is ready to accept some new - * rendering */ - if (data->draw_ready && data->frame_ready) - { - _draw (data); - data->draw_ready = FALSE; - data->frame_ready = FALSE; - } -} - -static void -_frame_callback (CoglOnscreen *onscreen, - CoglFrameEvent event, - CoglFrameInfo *info, - void *user_data) -{ - Data *data = user_data; - - if (event == COGL_FRAME_EVENT_SYNC) - { - data->draw_ready = TRUE; - _check_draw (data); - } -} - -static void -_new_frame_cb (CoglGstVideoSink *sink, - Data *data) -{ - data->frame_ready = TRUE; - _check_draw (data); -} - -static void -_resize_callback (CoglOnscreen *onscreen, - int width, - int height, - void *user_data) -{ - Data *data = user_data; - CoglGstRectangle available; - - data->onscreen_width = width; - data->onscreen_height = height; - - cogl_framebuffer_orthographic (data->fb, 0, 0, width, height, -1, 100); - - if (!data->video_pipeline) - return; - - available.x = 0; - available.y = 0; - available.width = width; - available.height = height; - cogl_gst_video_sink_fit_size (data->sink, - &available, - &data->video_output); -} - -/* - A callback like this should be attached to the cogl-pipeline-ready - signal. This way requesting the cogl pipeline before its creation - by the sink is avoided. At this point, user textures and snippets can - be added to the cogl pipeline. -*/ - -static void -_set_up_pipeline (gpointer instance, - gpointer user_data) -{ - Data* data = (Data*) user_data; - - data->video_pipeline = cogl_gst_video_sink_get_pipeline (data->sink); - - /* disable blending... */ - cogl_pipeline_set_blend (data->video_pipeline, - "RGBA = ADD (SRC_COLOR, 0)", NULL); - - /* Now that we know the video size we can perform letterboxing */ - _resize_callback (COGL_ONSCREEN (data->fb), - data->onscreen_width, - data->onscreen_height, - data); - - cogl_onscreen_add_frame_callback (COGL_ONSCREEN (data->fb), _frame_callback, - data, NULL); - - /* - The cogl-gst-new-frame signal is emitted when the cogl-gst sink has - retrieved a new frame and attached it to the cogl pipeline. This can be - used to make sure cogl doesn't do any unnecessary drawing i.e. keeps to the - frame-rate of the video. - */ - - g_signal_connect (data->sink, "new-frame", G_CALLBACK (_new_frame_cb), data); -} - -static CoglBool -is_uri (const char *str) -{ - const char *p = str; - - while (g_ascii_isalpha (*p)) - p++; - - return p > str && g_str_has_prefix (p, "://"); -} - -static CoglGstVideoSink * -find_cogl_gst_video_sink (GstElement *element) -{ - GstElement *sink_element = NULL; - GstIterator *iterator; - GstElement *iterator_value; - GValue value; - - if (!GST_IS_BIN (element)) - return NULL; - - iterator = gst_bin_iterate_recurse (GST_BIN (element)); - - g_value_init (&value, GST_TYPE_ELEMENT); - - while (gst_iterator_next (iterator, &value) == GST_ITERATOR_OK) - { - iterator_value = g_value_get_object (&value); - - g_value_reset (&value); - - if (COGL_GST_IS_VIDEO_SINK (iterator_value)) - { - sink_element = iterator_value; - break; - } - } - - g_value_unset (&value); - - gst_iterator_free (iterator); - - return COGL_GST_VIDEO_SINK (sink_element); -} - - -static CoglBool -make_pipeline_for_uri (CoglContext *ctx, - const char *uri, - GstElement **pipeline_out, - CoglGstVideoSink **sink_out, - GError **error) -{ - GstElement *pipeline; - GstElement *bin; - CoglGstVideoSink *sink; - GError *tmp_error = NULL; - - if (is_uri (uri)) - { - pipeline = gst_pipeline_new ("gst-player"); - bin = gst_element_factory_make ("playbin", "bin"); - - sink = cogl_gst_video_sink_new (ctx); - - g_object_set (G_OBJECT (bin), - "video-sink", - GST_ELEMENT (sink), - NULL); - - gst_bin_add (GST_BIN (pipeline), bin); - - g_object_set (G_OBJECT (bin), "uri", uri, NULL); - } - else - { - pipeline = gst_parse_launch (uri, &tmp_error); - - if (tmp_error) - { - if (pipeline) - g_object_unref (pipeline); - - g_propagate_error (error, tmp_error); - - return FALSE; - } - - sink = find_cogl_gst_video_sink (pipeline); - - if (sink == NULL) - { - g_set_error (error, - GST_STREAM_ERROR, - GST_STREAM_ERROR_FAILED, - "The pipeline does not contain a CoglGstVideoSink. " - "Make sure you add a 'coglsink' element somewhere in " - "the pipeline"); - g_object_unref (pipeline); - return FALSE; - } - - g_object_ref (sink); - - cogl_gst_video_sink_set_context (sink, ctx); - } - - *pipeline_out = pipeline; - *sink_out = sink; - - return TRUE; -} - -int -main (int argc, - char **argv) -{ - Data data; - CoglContext *ctx; - CoglOnscreen *onscreen; - GstElement *pipeline; - GSource *cogl_source; - GstBus *bus; - char *uri; - GError *error = NULL; - - memset (&data, 0, sizeof (Data)); - - /* Set the necessary cogl elements */ - - ctx = cogl_context_new (NULL, NULL); - - onscreen = cogl_onscreen_new (ctx, 640, 480); - cogl_onscreen_set_resizable (onscreen, TRUE); - cogl_onscreen_add_resize_callback (onscreen, _resize_callback, &data, NULL); - cogl_onscreen_show (onscreen); - - data.fb = onscreen; - cogl_framebuffer_orthographic (data.fb, 0, 0, 640, 480, -1, 100); - - data.border_pipeline = cogl_pipeline_new (ctx); - cogl_pipeline_set_color4f (data.border_pipeline, 0, 0, 0, 1); - /* disable blending */ - cogl_pipeline_set_blend (data.border_pipeline, - "RGBA = ADD (SRC_COLOR, 0)", NULL); - - /* Intialize GStreamer */ - - gst_init (&argc, &argv); - - /* - Create the cogl-gst video sink by calling the cogl_gst_video_sink_new - function and passing it a CoglContext (this is used to create the - CoglPipeline and the texures for each frame). Alternatively you can use - gst_element_factory_make ("coglsink", "some_name") and then set the - context with cogl_gst_video_sink_set_context. - */ - - if (argc < 2) - uri = "http://docs.gstreamer.com/media/sintel_trailer-480p.webm"; - else - uri = argv[1]; - - if (!make_pipeline_for_uri (ctx, uri, &pipeline, &data.sink, &error)) - { - g_print ("Error creating pipeline: %s\n", error->message); - g_clear_error (&error); - return EXIT_FAILURE; - } - - gst_element_set_state (pipeline, GST_STATE_PLAYING); - bus = gst_pipeline_get_bus (GST_PIPELINE (pipeline)); - gst_bus_add_watch (bus, _bus_watch, &data); - - data.main_loop = g_main_loop_new (NULL, FALSE); - - cogl_source = cogl_glib_source_new (ctx, G_PRIORITY_DEFAULT); - g_source_attach (cogl_source, NULL); - - /* - The cogl-pipeline-ready signal tells you when the cogl pipeline is - initialized i.e. when cogl-gst has figured out the video format and - is prepared to retrieve and attach the first frame of the video. - */ - - g_signal_connect (data.sink, "pipeline-ready", - G_CALLBACK (_set_up_pipeline), &data); - - data.draw_ready = TRUE; - data.frame_ready = FALSE; - - g_main_loop_run (data.main_loop); - - g_source_destroy (cogl_source); - g_source_unref (cogl_source); - - g_main_loop_unref (data.main_loop); - - return 0; -} diff --git a/examples/cogl-crate.c b/examples/cogl-crate.c deleted file mode 100644 index d04e30857..000000000 --- a/examples/cogl-crate.c +++ /dev/null @@ -1,300 +0,0 @@ -#include -#include - -/* The state for this example... */ -typedef struct _Data -{ - CoglFramebuffer *fb; - int framebuffer_width; - int framebuffer_height; - - CoglMatrix view; - - CoglIndices *indices; - CoglPrimitive *prim; - CoglTexture *texture; - CoglPipeline *crate_pipeline; - - CoglPangoFontMap *pango_font_map; - PangoContext *pango_context; - PangoFontDescription *pango_font_desc; - - PangoLayout *hello_label; - int hello_label_width; - int hello_label_height; - - GTimer *timer; - - CoglBool swap_ready; - -} Data; - -/* A static identity matrix initialized for convenience. */ -static CoglMatrix identity; -/* static colors initialized for convenience. */ -static CoglColor white; - -/* A cube modelled using 4 vertices for each face. - * - * We use an index buffer when drawing the cube later so the GPU will - * actually read each face as 2 separate triangles. - */ -static CoglVertexP3T2 vertices[] = -{ - /* Front face */ - { /* pos = */ -1.0f, -1.0f, 1.0f, /* tex coords = */ 0.0f, 1.0f}, - { /* pos = */ 1.0f, -1.0f, 1.0f, /* tex coords = */ 1.0f, 1.0f}, - { /* pos = */ 1.0f, 1.0f, 1.0f, /* tex coords = */ 1.0f, 0.0f}, - { /* pos = */ -1.0f, 1.0f, 1.0f, /* tex coords = */ 0.0f, 0.0f}, - - /* Back face */ - { /* pos = */ -1.0f, -1.0f, -1.0f, /* tex coords = */ 1.0f, 0.0f}, - { /* pos = */ -1.0f, 1.0f, -1.0f, /* tex coords = */ 1.0f, 1.0f}, - { /* pos = */ 1.0f, 1.0f, -1.0f, /* tex coords = */ 0.0f, 1.0f}, - { /* pos = */ 1.0f, -1.0f, -1.0f, /* tex coords = */ 0.0f, 0.0f}, - - /* Top face */ - { /* pos = */ -1.0f, 1.0f, -1.0f, /* tex coords = */ 0.0f, 1.0f}, - { /* pos = */ -1.0f, 1.0f, 1.0f, /* tex coords = */ 0.0f, 0.0f}, - { /* pos = */ 1.0f, 1.0f, 1.0f, /* tex coords = */ 1.0f, 0.0f}, - { /* pos = */ 1.0f, 1.0f, -1.0f, /* tex coords = */ 1.0f, 1.0f}, - - /* Bottom face */ - { /* pos = */ -1.0f, -1.0f, -1.0f, /* tex coords = */ 1.0f, 1.0f}, - { /* pos = */ 1.0f, -1.0f, -1.0f, /* tex coords = */ 0.0f, 1.0f}, - { /* pos = */ 1.0f, -1.0f, 1.0f, /* tex coords = */ 0.0f, 0.0f}, - { /* pos = */ -1.0f, -1.0f, 1.0f, /* tex coords = */ 1.0f, 0.0f}, - - /* Right face */ - { /* pos = */ 1.0f, -1.0f, -1.0f, /* tex coords = */ 1.0f, 0.0f}, - { /* pos = */ 1.0f, 1.0f, -1.0f, /* tex coords = */ 1.0f, 1.0f}, - { /* pos = */ 1.0f, 1.0f, 1.0f, /* tex coords = */ 0.0f, 1.0f}, - { /* pos = */ 1.0f, -1.0f, 1.0f, /* tex coords = */ 0.0f, 0.0f}, - - /* Left face */ - { /* pos = */ -1.0f, -1.0f, -1.0f, /* tex coords = */ 0.0f, 0.0f}, - { /* pos = */ -1.0f, -1.0f, 1.0f, /* tex coords = */ 1.0f, 0.0f}, - { /* pos = */ -1.0f, 1.0f, 1.0f, /* tex coords = */ 1.0f, 1.0f}, - { /* pos = */ -1.0f, 1.0f, -1.0f, /* tex coords = */ 0.0f, 1.0f} -}; - -static void -paint (Data *data) -{ - CoglFramebuffer *fb = data->fb; - float rotation; - - cogl_framebuffer_clear4f (fb, - COGL_BUFFER_BIT_COLOR|COGL_BUFFER_BIT_DEPTH, - 0, 0, 0, 1); - - cogl_framebuffer_push_matrix (fb); - - cogl_framebuffer_translate (fb, - data->framebuffer_width / 2, - data->framebuffer_height / 2, - 0); - - cogl_framebuffer_scale (fb, 75, 75, 75); - - /* Update the rotation based on the time the application has been - running so that we get a linear animation regardless of the frame - rate */ - rotation = g_timer_elapsed (data->timer, NULL) * 60.0f; - - /* Rotate the cube separately around each axis. - * - * Note: Cogl matrix manipulation follows the same rules as for - * OpenGL. We use column-major matrices and - if you consider the - * transformations happening to the model - then they are combined - * in reverse order which is why the rotation is done last, since - * we want it to be a rotation around the origin, before it is - * scaled and translated. - */ - cogl_framebuffer_rotate (fb, rotation, 0, 0, 1); - cogl_framebuffer_rotate (fb, rotation, 0, 1, 0); - cogl_framebuffer_rotate (fb, rotation, 1, 0, 0); - - cogl_primitive_draw (data->prim, fb, data->crate_pipeline); - - cogl_framebuffer_pop_matrix (fb); - - /* And finally render our Pango layouts... */ - - cogl_pango_show_layout (fb, data->hello_label, - (data->framebuffer_width / 2) - - (data->hello_label_width / 2), - (data->framebuffer_height / 2) - - (data->hello_label_height / 2), - &white); -} - -static void -frame_event_cb (CoglOnscreen *onscreen, - CoglFrameEvent event, - CoglFrameInfo *info, - void *user_data) -{ - Data *data = user_data; - - if (event == COGL_FRAME_EVENT_SYNC) - data->swap_ready = TRUE; -} - -int -main (int argc, char **argv) -{ - CoglContext *ctx; - CoglOnscreen *onscreen; - CoglFramebuffer *fb; - CoglError *error = NULL; - Data data; - PangoRectangle hello_label_size; - float fovy, aspect, z_near, z_2d, z_far; - CoglDepthState depth_state; - - ctx = cogl_context_new (NULL, &error); - if (!ctx) { - fprintf (stderr, "Failed to create context: %s\n", error->message); - return 1; - } - - onscreen = cogl_onscreen_new (ctx, 640, 480); - fb = onscreen; - data.fb = fb; - data.framebuffer_width = cogl_framebuffer_get_width (fb); - data.framebuffer_height = cogl_framebuffer_get_height (fb); - - data.timer = g_timer_new (); - - cogl_onscreen_show (onscreen); - - cogl_framebuffer_set_viewport (fb, 0, 0, - data.framebuffer_width, - data.framebuffer_height); - - fovy = 60; /* y-axis field of view */ - aspect = (float)data.framebuffer_width/(float)data.framebuffer_height; - z_near = 0.1; /* distance to near clipping plane */ - z_2d = 1000; /* position to 2d plane */ - z_far = 2000; /* distance to far clipping plane */ - - cogl_framebuffer_perspective (fb, fovy, aspect, z_near, z_far); - - /* Since the pango renderer emits geometry in pixel/device coordinates - * and the anti aliasing is implemented with the assumption that the - * geometry *really* does end up pixel aligned, we setup a modelview - * matrix so that for geometry in the plane z = 0 we exactly map x - * coordinates in the range [0,stage_width] and y coordinates in the - * range [0,stage_height] to the framebuffer extents with (0,0) being - * the top left. - * - * This is roughly what Clutter does for a ClutterStage, but this - * demonstrates how it is done manually using Cogl. - */ - cogl_matrix_init_identity (&data.view); - cogl_matrix_view_2d_in_perspective (&data.view, fovy, aspect, z_near, z_2d, - data.framebuffer_width, - data.framebuffer_height); - cogl_framebuffer_set_modelview_matrix (fb, &data.view); - - /* Initialize some convenient constants */ - cogl_matrix_init_identity (&identity); - cogl_color_init_from_4ub (&white, 0xff, 0xff, 0xff, 0xff); - - /* rectangle indices allow the GPU to interpret a list of quads (the - * faces of our cube) as a list of triangles. - * - * Since this is a very common thing to do - * cogl_get_rectangle_indices() is a convenience function for - * accessing internal index buffers that can be shared. - */ - data.indices = cogl_get_rectangle_indices (ctx, 6 /* n_rectangles */); - data.prim = cogl_primitive_new_p3t2 (ctx, COGL_VERTICES_MODE_TRIANGLES, - G_N_ELEMENTS (vertices), - vertices); - /* Each face will have 6 indices so we have 6 * 6 indices in total... */ - cogl_primitive_set_indices (data.prim, - data.indices, - 6 * 6); - - /* Load a jpeg crate texture from a file */ - printf ("crate.jpg (CC by-nc-nd http://bit.ly/9kP45T) ShadowRunner27 http://bit.ly/m1YXLh\n"); - data.texture = - cogl_texture_2d_new_from_file (ctx, - COGL_EXAMPLES_DATA "crate.jpg", - &error); - if (!data.texture) - g_error ("Failed to load texture: %s", error->message); - - /* a CoglPipeline conceptually describes all the state for vertex - * processing, fragment processing and blending geometry. When - * drawing the geometry for the crate this pipeline says to sample a - * single texture during fragment processing... */ - data.crate_pipeline = cogl_pipeline_new (ctx); - cogl_pipeline_set_layer_texture (data.crate_pipeline, 0, data.texture); - - /* Since the box is made of multiple triangles that will overlap - * when drawn and we don't control the order they are drawn in, we - * enable depth testing to make sure that triangles that shouldn't - * be visible get culled by the GPU. */ - cogl_depth_state_init (&depth_state); - cogl_depth_state_set_test_enabled (&depth_state, TRUE); - - cogl_pipeline_set_depth_state (data.crate_pipeline, &depth_state, NULL); - - /* Setup a Pango font map and context */ - - data.pango_font_map = COGL_PANGO_FONT_MAP (cogl_pango_font_map_new()); - - cogl_pango_font_map_set_use_mipmapping (data.pango_font_map, TRUE); - - data.pango_context = cogl_pango_font_map_create_context (data.pango_font_map); - - data.pango_font_desc = pango_font_description_new (); - pango_font_description_set_family (data.pango_font_desc, "Sans"); - pango_font_description_set_size (data.pango_font_desc, 30 * PANGO_SCALE); - - /* Setup the "Hello Cogl" text */ - - data.hello_label = pango_layout_new (data.pango_context); - pango_layout_set_font_description (data.hello_label, data.pango_font_desc); - pango_layout_set_text (data.hello_label, "Hello Cogl", -1); - - pango_layout_get_extents (data.hello_label, NULL, &hello_label_size); - data.hello_label_width = PANGO_PIXELS (hello_label_size.width); - data.hello_label_height = PANGO_PIXELS (hello_label_size.height); - - data.swap_ready = TRUE; - - cogl_onscreen_add_frame_callback (COGL_ONSCREEN (fb), - frame_event_cb, - &data, - NULL); /* destroy notify */ - - - while (1) - { - CoglPollFD *poll_fds; - int n_poll_fds; - int64_t timeout; - - if (data.swap_ready) - { - paint (&data); - cogl_onscreen_swap_buffers (COGL_ONSCREEN (fb)); - } - - cogl_poll_renderer_get_info (cogl_context_get_renderer (ctx), - &poll_fds, &n_poll_fds, &timeout); - - g_poll ((GPollFD *) poll_fds, n_poll_fds, - timeout == -1 ? -1 : timeout / 1000); - - cogl_poll_renderer_dispatch (cogl_context_get_renderer (ctx), - poll_fds, n_poll_fds); - } - - return 0; -} - diff --git a/examples/cogl-emscripten-hello.c b/examples/cogl-emscripten-hello.c deleted file mode 100644 index e969e95d4..000000000 --- a/examples/cogl-emscripten-hello.c +++ /dev/null @@ -1,149 +0,0 @@ -#include -#include -#include -#include -#include "emscripten-example-js.h" - -/* This short example is just to demonstrate using Cogl with - * Emscripten using SDL to receive input events */ - -typedef struct Data -{ - CoglPrimitive *triangle; - CoglPipeline *pipeline; - float center_x, center_y; - CoglFramebuffer *fb; - CoglBool redraw_queued; - CoglBool ready_to_draw; -} Data; - -static Data data; -static CoglContext *ctx; - -static void -redraw (Data *data) -{ - CoglFramebuffer *fb = data->fb; - - cogl_framebuffer_clear4f (fb, COGL_BUFFER_BIT_COLOR, 0, 0, 0, 1); - - cogl_framebuffer_push_matrix (fb); - cogl_framebuffer_translate (fb, data->center_x, -data->center_y, 0.0f); - - cogl_primitive_draw (data->triangle, fb, data->pipeline); - cogl_framebuffer_pop_matrix (fb); - - cogl_onscreen_swap_buffers (COGL_ONSCREEN (fb)); -} - -static void -handle_event (Data *data, SDL_Event *event) -{ - switch (event->type) - { - case SDL_MOUSEMOTION: - { - int width = - cogl_framebuffer_get_width (COGL_FRAMEBUFFER (data->fb)); - int height = - cogl_framebuffer_get_height (COGL_FRAMEBUFFER (data->fb)); - - data->center_x = event->motion.x * 2.0f / width - 1.0f; - data->center_y = event->motion.y * 2.0f / height - 1.0f; - - data->redraw_queued = TRUE; - } - break; - } -} - -static void -frame_cb (CoglOnscreen *onscreen, - CoglFrameEvent event, - CoglFrameInfo *info, - void *user_data) -{ - Data *data = user_data; - - if (event == COGL_FRAME_EVENT_SYNC) - data->ready_to_draw = TRUE; -} - -static void -mainloop (void) -{ - SDL_Event event; - - while (SDL_PollEvent (&event)) - { - handle_event (&data, &event); - cogl_sdl_handle_event (ctx, &event); - } - - if (data.redraw_queued && data.ready_to_draw) - { - data.redraw_queued = FALSE; - data.ready_to_draw = FALSE; - redraw (&data); - } - - /* NB: The mainloop will be automatically resumed if user input is received */ - if (!data.redraw_queued) - emscripten_pause_main_loop (); - - cogl_sdl_idle (ctx); -} - -int -main (int argc, char **argv) -{ - CoglOnscreen *onscreen; - CoglError *error = NULL; - CoglVertexP2C4 triangle_vertices[] = { - {0, 0.7, 0xff, 0x00, 0x00, 0xff}, - {-0.7, -0.7, 0x00, 0xff, 0x00, 0xff}, - {0.7, -0.7, 0x00, 0x00, 0xff, 0xff} - }; - - ctx = cogl_sdl_context_new (SDL_USEREVENT, &error); - if (!ctx) - { - fprintf (stderr, "Failed to create context: %s\n", error->message); - return 1; - } - - onscreen = cogl_onscreen_new (ctx, 800, 600); - data.fb = COGL_FRAMEBUFFER (onscreen); - - cogl_onscreen_add_frame_callback (onscreen, - frame_cb, - &data, - NULL /* destroy callback */); - - data.center_x = 0.0f; - data.center_y = 0.0f; - - cogl_onscreen_show (onscreen); - - data.triangle = cogl_primitive_new_p2c4 (ctx, COGL_VERTICES_MODE_TRIANGLES, - 3, triangle_vertices); - data.pipeline = cogl_pipeline_new (ctx); - - data.redraw_queued = TRUE; - data.ready_to_draw = TRUE; - - /* The emscripten mainloop isn't event driven, it's periodic and so - * we aim to pause the emscripten mainlooop whenever we don't have a - * redraw queued. What we do instead is hook into the real browser - * mainloop using this javascript binding api to add an input event - * listener that will resume the emscripten mainloop whenever input - * is received. - */ - example_js_add_input_listener (); - - emscripten_set_main_loop (mainloop, -1, TRUE); - - cogl_object_unref (ctx); - - return 0; -} diff --git a/examples/cogl-gjs.js b/examples/cogl-gjs.js deleted file mode 100644 index 6652e166e..000000000 --- a/examples/cogl-gjs.js +++ /dev/null @@ -1,46 +0,0 @@ -const Cogl = imports.gi.Cogl; -const GLib = imports.gi.GLib; -const Lang = imports.lang; - -let renderer = new Cogl.Renderer(); -let display = new Cogl.Display(renderer, new Cogl.OnscreenTemplate(new Cogl.SwapChain())); -let ctx = new Cogl.Context(display); - -// Should be able to replace the 3 previous lines with : -// let ctx = new Cogl.Context(null); -// But crashing for some reason. - -// GLib mainloop integration -let gsource = Cogl.glib_renderer_source_new(renderer, 0); -let loop = GLib.MainLoop.new(null, false); -gsource.attach(loop.get_context()); - -// Onscreen creation -let onscreen = new Cogl.Onscreen(ctx, 800, 600); -onscreen.show(); - -// Drawing pipeline -let crate = Cogl.Texture2D.new_from_file(ctx, 'crate.jpg'); -let pipeline = new Cogl.Pipeline(ctx); -pipeline.set_layer_texture(0, crate); -let clearColor = new Cogl.Color(); -clearColor.init_from_4f(0, 0, 0, 1.0); - -// Redraw callback -let closure = onscreen.add_dirty_callback(Lang.bind(this, function() { - onscreen.clear(Cogl.BufferBit.COLOR, clearColor); - onscreen.draw_rectangle(pipeline, -1, -1, 1, 1); - onscreen.swap_buffers(); - return true; -}), null); - -// Quit after 5s -let tm = GLib.timeout_source_new(5000); -tm.set_callback(Lang.bind(this, function() { - loop.quit(); - return false; -}), null); -tm.attach(loop.get_context()); - -// Run! -loop.run(); diff --git a/examples/cogl-gles2-context.c b/examples/cogl-gles2-context.c deleted file mode 100644 index da52423b7..000000000 --- a/examples/cogl-gles2-context.c +++ /dev/null @@ -1,138 +0,0 @@ -#include -#include -#include -#include - -#define OFFSCREEN_WIDTH 100 -#define OFFSCREEN_HEIGHT 100 - -typedef struct _Data -{ - CoglContext *ctx; - CoglFramebuffer *fb; - CoglPrimitive *triangle; - CoglPipeline *pipeline; - - CoglTexture *offscreen_texture; - CoglOffscreen *offscreen; - CoglGLES2Context *gles2_ctx; - const CoglGLES2Vtable *gles2_vtable; -} Data; - -static gboolean -paint_cb (void *user_data) -{ - Data *data = user_data; - CoglError *error = NULL; - const CoglGLES2Vtable *gles2 = data->gles2_vtable; - - /* Draw scene with GLES2 */ - if (!cogl_push_gles2_context (data->ctx, - data->gles2_ctx, - data->fb, - data->fb, - &error)) - { - g_error ("Failed to push gles2 context: %s\n", error->message); - } - - /* Clear offscreen framebuffer with a random color */ - gles2->glClearColor (g_random_double (), - g_random_double (), - g_random_double (), - 1.0f); - gles2->glClear (GL_COLOR_BUFFER_BIT); - - cogl_pop_gles2_context (data->ctx); - - /* Draw scene with Cogl */ - cogl_primitive_draw (data->triangle, data->fb, data->pipeline); - - cogl_onscreen_swap_buffers (COGL_ONSCREEN (data->fb)); - - return FALSE; /* remove the callback */ -} - -static void -frame_event_cb (CoglOnscreen *onscreen, - CoglFrameEvent event, - CoglFrameInfo *info, - void *user_data) -{ - if (event == COGL_FRAME_EVENT_SYNC) - paint_cb (user_data); -} - -int -main (int argc, char **argv) -{ - Data data; - CoglOnscreen *onscreen; - CoglError *error = NULL; - CoglVertexP2C4 triangle_vertices[] = { - {0, 0.7, 0xff, 0x00, 0x00, 0xff}, - {-0.7, -0.7, 0x00, 0xff, 0x00, 0xff}, - {0.7, -0.7, 0x00, 0x00, 0xff, 0xff} - }; - GSource *cogl_source; - GMainLoop *loop; - CoglRenderer *renderer; - CoglDisplay *display; - - renderer = cogl_renderer_new (); - cogl_renderer_add_constraint (renderer, - COGL_RENDERER_CONSTRAINT_SUPPORTS_COGL_GLES2); - display = cogl_display_new (renderer, NULL); - data.ctx = cogl_context_new (display, NULL); - - onscreen = cogl_onscreen_new (data.ctx, 640, 480); - cogl_onscreen_show (onscreen); - data.fb = onscreen; - - /* Prepare onscreen primitive */ - data.triangle = cogl_primitive_new_p2c4 (data.ctx, - COGL_VERTICES_MODE_TRIANGLES, - 3, triangle_vertices); - data.pipeline = cogl_pipeline_new (data.ctx); - - data.offscreen_texture = - cogl_texture_2d_new_with_size (data.ctx, - OFFSCREEN_WIDTH, - OFFSCREEN_HEIGHT); - data.offscreen = cogl_offscreen_new_with_texture (data.offscreen_texture); - - data.gles2_ctx = cogl_gles2_context_new (data.ctx, &error); - if (!data.gles2_ctx) { - g_error ("Failed to create GLES2 context: %s\n", error->message); - } - - data.gles2_vtable = cogl_gles2_context_get_vtable (data.gles2_ctx); - - /* Draw scene with GLES2 */ - if (!cogl_push_gles2_context (data.ctx, - data.gles2_ctx, - data.fb, - data.fb, - &error)) - { - g_error ("Failed to push gles2 context: %s\n", error->message); - } - - cogl_pop_gles2_context (data.ctx); - - cogl_source = cogl_glib_source_new (data.ctx, G_PRIORITY_DEFAULT); - - g_source_attach (cogl_source, NULL); - - cogl_onscreen_add_frame_callback (COGL_ONSCREEN (data.fb), - frame_event_cb, - &data, - NULL); /* destroy notify */ - - g_idle_add (paint_cb, &data); - - loop = g_main_loop_new (NULL, TRUE); - g_main_loop_run (loop); - - return 0; -} diff --git a/examples/cogl-gles2-gears.c b/examples/cogl-gles2-gears.c deleted file mode 100644 index 048cd27d8..000000000 --- a/examples/cogl-gles2-gears.c +++ /dev/null @@ -1,825 +0,0 @@ -/* - * Copyright (C) 1999-2001 Brian Paul All Rights Reserved. - * - * Permission is hereby granted, free of charge, to any person obtaining a - * copy of this software and associated documentation files (the "Software"), - * to deal in the Software without restriction, including without limitation - * the rights to use, copy, modify, merge, publish, distribute, sublicense, - * and/or sell copies of the Software, and to permit persons to whom the - * Software is furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included - * in all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS - * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL - * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN - * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN - * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -/* - * Ported to GLES2. - * Kristian Høgsberg - * May 3, 2010 - * - * Improve GLES2 port: - * * Refactor gear drawing. - * * Use correct normals for surfaces. - * * Improve shader. - * * Use perspective projection transformation. - * * Add FPS count. - * * Add comments. - * Alexandros Frantzis - * Jul 13, 2010 - */ - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#define GL_GLEXT_PROTOTYPES - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#define STRIPS_PER_TOOTH 7 -#define VERTICES_PER_TOOTH 34 -#define GEAR_VERTEX_STRIDE 6 - -typedef struct _Data -{ - CoglContext *ctx; - CoglFramebuffer *fb; - - CoglGLES2Context *gles2_ctx; - - GTimer *timer; - int frames; - double last_elapsed; -} Data; - - -/** - * Struct describing the vertices in triangle strip - */ -struct vertex_strip { - /** The first vertex in the strip */ - GLint first; - /** The number of consecutive vertices in the strip after the first */ - GLint count; -}; - -/* Each vertex consist of GEAR_VERTEX_STRIDE GLfloat attributes */ -typedef GLfloat GearVertex[GEAR_VERTEX_STRIDE]; - -/** - * Struct representing a gear. - */ -struct gear { - /** The array of vertices comprising the gear */ - GearVertex *vertices; - /** The number of vertices comprising the gear */ - int nvertices; - /** The array of triangle strips comprising the gear */ - struct vertex_strip *strips; - /** The number of triangle strips comprising the gear */ - int nstrips; - /** The Vertex Buffer Object holding the vertices in the graphics card */ - GLuint vbo; -}; - -/** The view rotation [x, y, z] */ -static GLfloat view_rot[3] = { 20.0, 30.0, 0.0 }; -/** The gears */ -static struct gear *gear1, *gear2, *gear3; -/** The current gear rotation angle */ -static GLfloat angle = 0.0; -/** The location of the shader uniforms */ -static GLuint ModelViewProjectionMatrix_location, - NormalMatrix_location, - LightSourcePosition_location, - MaterialColor_location; -/** The projection matrix */ -static GLfloat ProjectionMatrix[16]; -/** The direction of the directional light for the scene */ -static const GLfloat LightSourcePosition[4] = { 5.0, 5.0, 10.0, 1.0}; - -#ifndef HAVE_SINCOS -static void -sincos (double x, double *sinx, double *cosx) -{ - *sinx = sin (x); - *cosx = cos (x); -} -#endif /* HAVE_SINCOS */ - -/** - * Fills a gear vertex. - * - * @param v the vertex to fill - * @param x the x coordinate - * @param y the y coordinate - * @param z the z coortinate - * @param n pointer to the normal table - * - * @return the operation error code - */ -static GearVertex * -vert (GearVertex *v, GLfloat x, GLfloat y, GLfloat z, GLfloat n[3]) -{ - v[0][0] = x; - v[0][1] = y; - v[0][2] = z; - v[0][3] = n[0]; - v[0][4] = n[1]; - v[0][5] = n[2]; - - return v + 1; -} - -/** - * Create a gear wheel. - * - * @param inner_radius radius of hole at center - * @param outer_radius radius at center of teeth - * @param width width of gear - * @param teeth number of teeth - * @param tooth_depth depth of tooth - * - * @return pointer to the constructed struct gear - */ -static struct gear * -create_gear (GLfloat inner_radius, GLfloat outer_radius, GLfloat width, - GLint teeth, GLfloat tooth_depth) -{ - GLfloat r0, r1, r2; - GLfloat da; - GearVertex *v; - struct gear *gear; - double s[5], c[5]; - GLfloat normal[3]; - int cur_strip = 0; - int i; - - /* Allocate memory for the gear */ - gear = malloc (sizeof *gear); - if (gear == NULL) - return NULL; - - /* Calculate the radii used in the gear */ - r0 = inner_radius; - r1 = outer_radius - tooth_depth / 2.0; - r2 = outer_radius + tooth_depth / 2.0; - - da = 2.0 * M_PI / teeth / 4.0; - - /* Allocate memory for the triangle strip information */ - gear->nstrips = STRIPS_PER_TOOTH * teeth; - gear->strips = calloc (gear->nstrips, sizeof (*gear->strips)); - - /* Allocate memory for the vertices */ - gear->vertices = calloc (VERTICES_PER_TOOTH * teeth, sizeof(*gear->vertices)); - v = gear->vertices; - - for (i = 0; i < teeth; i++) { - /* Calculate needed sin/cos for varius angles */ - sincos (i * 2.0 * M_PI / teeth, &s[0], &c[0]); - sincos (i * 2.0 * M_PI / teeth + da, &s[1], &c[1]); - sincos (i * 2.0 * M_PI / teeth + da * 2, &s[2], &c[2]); - sincos (i * 2.0 * M_PI / teeth + da * 3, &s[3], &c[3]); - sincos (i * 2.0 * M_PI / teeth + da * 4, &s[4], &c[4]); - - /* A set of macros for making the creation of the gears easier */ -#define GEAR_POINT(r, da) { (r) * c[(da)], (r) * s[(da)] } -#define SET_NORMAL(x, y, z) do { \ - normal[0] = (x); normal[1] = (y); normal[2] = (z); \ -} while(0) - -#define GEAR_VERT(v, point, sign) vert((v), p[(point)].x, p[(point)].y, (sign) * width * 0.5, normal) - -#define START_STRIP do { \ - gear->strips[cur_strip].first = v - gear->vertices; \ -} while(0); - -#define END_STRIP do { \ - int _tmp = (v - gear->vertices); \ - gear->strips[cur_strip].count = _tmp - gear->strips[cur_strip].first; \ - cur_strip++; \ -} while (0) - -#define QUAD_WITH_NORMAL(p1, p2) do { \ - SET_NORMAL((p[(p1)].y - p[(p2)].y), -(p[(p1)].x - p[(p2)].x), 0); \ - v = GEAR_VERT(v, (p1), -1); \ - v = GEAR_VERT(v, (p1), 1); \ - v = GEAR_VERT(v, (p2), -1); \ - v = GEAR_VERT(v, (p2), 1); \ -} while(0) - - { - struct point { - GLfloat x; - GLfloat y; - }; - - /* Create the 7 points (only x,y coords) used to draw a tooth */ - struct point p[7] = { - GEAR_POINT (r2, 1), // 0 - GEAR_POINT (r2, 2), // 1 - GEAR_POINT (r1, 0), // 2 - GEAR_POINT (r1, 3), // 3 - GEAR_POINT (r0, 0), // 4 - GEAR_POINT (r1, 4), // 5 - GEAR_POINT (r0, 4), // 6 - }; - - /* Front face */ - START_STRIP; - SET_NORMAL (0, 0, 1.0); - v = GEAR_VERT (v, 0, +1); - v = GEAR_VERT (v, 1, +1); - v = GEAR_VERT (v, 2, +1); - v = GEAR_VERT (v, 3, +1); - v = GEAR_VERT (v, 4, +1); - v = GEAR_VERT (v, 5, +1); - v = GEAR_VERT (v, 6, +1); - END_STRIP; - - /* Inner face */ - START_STRIP; - QUAD_WITH_NORMAL (4, 6); - END_STRIP; - - /* Back face */ - START_STRIP; - SET_NORMAL (0, 0, -1.0); - v = GEAR_VERT (v, 6, -1); - v = GEAR_VERT (v, 5, -1); - v = GEAR_VERT (v, 4, -1); - v = GEAR_VERT (v, 3, -1); - v = GEAR_VERT (v, 2, -1); - v = GEAR_VERT (v, 1, -1); - v = GEAR_VERT (v, 0, -1); - END_STRIP; - - /* Outer face */ - START_STRIP; - QUAD_WITH_NORMAL (0, 2); - END_STRIP; - - START_STRIP; - QUAD_WITH_NORMAL (1, 0); - END_STRIP; - - START_STRIP; - QUAD_WITH_NORMAL (3, 1); - END_STRIP; - - START_STRIP; - QUAD_WITH_NORMAL (5, 3); - END_STRIP; - } - } - - gear->nvertices = (v - gear->vertices); - - /* Store the vertices in a vertex buffer object (VBO) */ - glGenBuffers (1, &gear->vbo); - glBindBuffer (GL_ARRAY_BUFFER, gear->vbo); - glBufferData (GL_ARRAY_BUFFER, gear->nvertices * sizeof(GearVertex), - gear->vertices, GL_STATIC_DRAW); - - return gear; -} - -/** - * Multiplies two 4x4 matrices. - * - * The result is stored in matrix m. - * - * @param m the first matrix to multiply - * @param n the second matrix to multiply - */ -static void -multiply (GLfloat *m, const GLfloat *n) -{ - GLfloat tmp[16]; - const GLfloat *row, *column; - div_t d; - int i, j; - - for (i = 0; i < 16; i++) { - tmp[i] = 0; - d = div(i, 4); - row = n + d.quot * 4; - column = m + d.rem; - for (j = 0; j < 4; j++) - tmp[i] += row[j] * column[j * 4]; - } - memcpy (m, &tmp, sizeof tmp); -} - -/** - * Rotates a 4x4 matrix. - * - * @param[in,out] m the matrix to rotate - * @param angle the angle to rotate - * @param x the x component of the direction to rotate to - * @param y the y component of the direction to rotate to - * @param z the z component of the direction to rotate to - */ -static void -rotate (GLfloat *m, GLfloat angle, GLfloat x, GLfloat y, GLfloat z) -{ - double s, c; - - sincos (angle, &s, &c); - - { - GLfloat r[16] = { - x * x * (1 - c) + c, y * x * (1 - c) + z * s, x * z * (1 - c) - y * s, 0, - x * y * (1 - c) - z * s, y * y * (1 - c) + c, y * z * (1 - c) + x * s, 0, - x * z * (1 - c) + y * s, y * z * (1 - c) - x * s, z * z * (1 - c) + c, 0, - 0, 0, 0, 1 - }; - - multiply (m, r); - } -} - - -/** - * Translates a 4x4 matrix. - * - * @param[in,out] m the matrix to translate - * @param x the x component of the direction to translate to - * @param y the y component of the direction to translate to - * @param z the z component of the direction to translate to - */ -static void -translate(GLfloat *m, GLfloat x, GLfloat y, GLfloat z) -{ - GLfloat t[16] = { 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, x, y, z, 1 }; - - multiply (m, t); -} - -/** - * Creates an identity 4x4 matrix. - * - * @param m the matrix make an identity matrix - */ -static void -identity (GLfloat *m) -{ - GLfloat t[16] = { - 1.0, 0.0, 0.0, 0.0, - 0.0, 1.0, 0.0, 0.0, - 0.0, 0.0, 1.0, 0.0, - 0.0, 0.0, 0.0, 1.0, - }; - - memcpy (m, t, sizeof(t)); -} - -/** - * Transposes a 4x4 matrix. - * - * @param m the matrix to transpose - */ -static void -transpose (GLfloat *m) -{ - GLfloat t[16] = { - m[0], m[4], m[8], m[12], - m[1], m[5], m[9], m[13], - m[2], m[6], m[10], m[14], - m[3], m[7], m[11], m[15]}; - - memcpy (m, t, sizeof(t)); -} - -/** - * Inverts a 4x4 matrix. - * - * This function can currently handle only pure translation-rotation matrices. - * Read http://www.gamedev.net/community/forums/topic.asp?topic_id=425118 - * for an explanation. - */ -static void -invert (GLfloat *m) -{ - GLfloat t[16]; - identity (t); - - // Extract and invert the translation part 't'. The inverse of a - // translation matrix can be calculated by negating the translation - // coordinates. - t[12] = -m[12]; t[13] = -m[13]; t[14] = -m[14]; - - // Invert the rotation part 'r'. The inverse of a rotation matrix is - // equal to its transpose. - m[12] = m[13] = m[14] = 0; - transpose (m); - - // inv (m) = inv (r) * inv (t) - multiply (m, t); -} - -/** - * Calculate a perspective projection transformation. - * - * @param m the matrix to save the transformation in - * @param fovy the field of view in the y direction - * @param aspect the view aspect ratio - * @param zNear the near clipping plane - * @param zFar the far clipping plane - */ -static void -perspective (GLfloat *m, GLfloat fovy, GLfloat aspect, GLfloat zNear, GLfloat zFar) -{ - GLfloat tmp[16]; - double sine, cosine, cotangent, deltaZ; - GLfloat radians = fovy / 2 * M_PI / 180; - - identity (tmp); - - deltaZ = zFar - zNear; - sincos (radians, &sine, &cosine); - - if ((deltaZ == 0) || (sine == 0) || (aspect == 0)) - return; - - cotangent = cosine / sine; - - tmp[0] = cotangent / aspect; - tmp[5] = cotangent; - tmp[10] = -(zFar + zNear) / deltaZ; - tmp[11] = -1; - tmp[14] = -2 * zNear * zFar / deltaZ; - tmp[15] = 0; - - memcpy (m, tmp, sizeof(tmp)); -} - -/** - * Draws a gear. - * - * @param gear the gear to draw - * @param transform the current transformation matrix - * @param x the x position to draw the gear at - * @param y the y position to draw the gear at - * @param angle the rotation angle of the gear - * @param color the color of the gear - */ -static void -draw_gear (struct gear *gear, GLfloat *transform, - GLfloat x, GLfloat y, GLfloat angle, const GLfloat color[4]) -{ - GLfloat model_view[16]; - GLfloat normal_matrix[16]; - GLfloat model_view_projection[16]; - int n; - - /* Translate and rotate the gear */ - memcpy(model_view, transform, sizeof (model_view)); - translate(model_view, x, y, 0); - rotate(model_view, 2 * M_PI * angle / 360.0, 0, 0, 1); - - /* Create and set the ModelViewProjectionMatrix */ - memcpy (model_view_projection, - ProjectionMatrix, - sizeof(model_view_projection)); - multiply (model_view_projection, model_view); - - glUniformMatrix4fv (ModelViewProjectionMatrix_location, 1, GL_FALSE, - model_view_projection); - - /* - * Create and set the NormalMatrix. It's the inverse transpose of the - * ModelView matrix. - */ - memcpy (normal_matrix, model_view, sizeof (normal_matrix)); - invert (normal_matrix); - transpose (normal_matrix); - glUniformMatrix4fv (NormalMatrix_location, 1, GL_FALSE, normal_matrix); - - /* Set the gear color */ - glUniform4fv (MaterialColor_location, 1, color); - - /* Set the vertex buffer object to use */ - glBindBuffer (GL_ARRAY_BUFFER, gear->vbo); - - /* Set up the position of the attributes in the vertex buffer object */ - glVertexAttribPointer (0, 3, GL_FLOAT, GL_FALSE, - 6 * sizeof(GLfloat), NULL); - glVertexAttribPointer (1, 3, GL_FLOAT, GL_FALSE, - 6 * sizeof(GLfloat), (GLfloat *) 0 + 3); - - /* Enable the attributes */ - glEnableVertexAttribArray (0); - glEnableVertexAttribArray (1); - - /* Draw the triangle strips that comprise the gear */ - for (n = 0; n < gear->nstrips; n++) - glDrawArrays (GL_TRIANGLE_STRIP, - gear->strips[n].first, - gear->strips[n].count); - - /* Disable the attributes */ - glDisableVertexAttribArray (1); - glDisableVertexAttribArray (0); -} - -/** - * Draws the gears. - */ -static void -gears_draw(void) -{ - const static GLfloat red[4] = { 0.8, 0.1, 0.0, 1.0 }; - const static GLfloat green[4] = { 0.0, 0.8, 0.2, 1.0 }; - const static GLfloat blue[4] = { 0.2, 0.2, 1.0, 1.0 }; - GLfloat transform[16]; - identity(transform); - - glClearColor (0.0, 0.0, 0.0, 0.0); - glClear (GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - /* Translate and rotate the view */ - translate (transform, 0, 0, -20); - rotate (transform, 2 * M_PI * view_rot[0] / 360.0, 1, 0, 0); - rotate (transform, 2 * M_PI * view_rot[1] / 360.0, 0, 1, 0); - rotate (transform, 2 * M_PI * view_rot[2] / 360.0, 0, 0, 1); - - /* Draw the gears */ - draw_gear (gear1, transform, -3.0, -2.0, angle, red); - draw_gear (gear2, transform, 3.1, -2.0, -2 * angle - 9.0, green); - draw_gear (gear3, transform, -3.1, 4.2, -2 * angle - 25.0, blue); -} - -static gboolean -paint_cb (void *user_data) -{ - Data *data = user_data; - double elapsed = g_timer_elapsed (data->timer, NULL); - double dt = elapsed - data->last_elapsed; - CoglError *error = NULL; - - /* Draw scene with GLES2 */ - if (!cogl_push_gles2_context (data->ctx, - data->gles2_ctx, - data->fb, - data->fb, - &error)) - { - g_error ("Failed to push gles2 context: %s\n", error->message); - } - - gears_draw (); - - cogl_pop_gles2_context (data->ctx); - - cogl_onscreen_swap_buffers (COGL_ONSCREEN (data->fb)); - - /* advance rotation for next frame */ - angle += 70.0 * dt; /* 70 degrees per second */ - if (angle > 3600.0) - angle -= 3600.0; - - data->frames++; - - if (elapsed > 5.0) { - GLfloat fps = data->frames / elapsed; - printf ("%d frames in %3.1f seconds = %6.3f FPS\n", - data->frames, elapsed, fps); - g_timer_reset (data->timer); - data->last_elapsed = 0; - data->frames = 0; - }else - data->last_elapsed = elapsed; - - return FALSE; /* remove the callback */ -} - -static void -frame_event_cb (CoglOnscreen *onscreen, - CoglFrameEvent event, - CoglFrameInfo *info, - void *user_data) -{ - if (event == COGL_FRAME_EVENT_SYNC) - paint_cb (user_data); -} - -/** - * Handles a new window size or exposure. - * - * @param width the window width - * @param height the window height - */ -static void -gears_reshape (int width, int height) -{ - /* Update the projection matrix */ - perspective (ProjectionMatrix, 60.0, width / (float)height, 1.0, 1024.0); - - /* Set the viewport */ - glViewport (0, 0, (GLint) width, (GLint) height); -} - -#if 0 -/** - * Handles special eglut events. - * - * @param special the event to handle. - */ -static void -gears_special(int special) -{ - switch (special) { - case EGLUT_KEY_LEFT: - view_rot[1] += 5.0; - break; - case EGLUT_KEY_RIGHT: - view_rot[1] -= 5.0; - break; - case EGLUT_KEY_UP: - view_rot[0] += 5.0; - break; - case EGLUT_KEY_DOWN: - view_rot[0] -= 5.0; - break; - } -} -#endif - -static const char vertex_shader[] = - "attribute vec3 position;\n" - "attribute vec3 normal;\n" - "\n" - "uniform mat4 ModelViewProjectionMatrix;\n" - "uniform mat4 NormalMatrix;\n" - "uniform vec4 LightSourcePosition;\n" - "uniform vec4 MaterialColor;\n" - "\n" - "varying vec4 Color;\n" - "\n" - "void main(void)\n" - "{\n" - " // Transform the normal to eye coordinates\n" - " vec3 N = normalize(vec3(NormalMatrix * vec4(normal, 1.0)));\n" - "\n" - " // The LightSourcePosition is actually its direction for directional light\n" - " vec3 L = normalize(LightSourcePosition.xyz);\n" - "\n" - " // Multiply the diffuse value by the vertex color (which is fixed in this case)\n" - " // to get the actual color that we will use to draw this vertex with\n" - " float diffuse = max(dot(N, L), 0.0);\n" - " Color = diffuse * MaterialColor;\n" - "\n" - " // Transform the position to clip coordinates\n" - " gl_Position = ModelViewProjectionMatrix * vec4(position, 1.0);\n" - "}"; - -static const char fragment_shader[] = - "precision mediump float;\n" - "varying vec4 Color;\n" - "\n" - "void main(void)\n" - "{\n" - " gl_FragColor = Color;\n" - "}"; - -static void -gears_init(void) -{ - GLuint v, f, program; - const char *p; - char msg[512]; - - glEnable (GL_CULL_FACE); - glEnable (GL_DEPTH_TEST); - - /* Compile the vertex shader */ - p = vertex_shader; - v = glCreateShader (GL_VERTEX_SHADER); - glShaderSource (v, 1, &p, NULL); - glCompileShader (v); - glGetShaderInfoLog (v, sizeof msg, NULL, msg); - printf ("vertex shader info: %s\n", msg); - - /* Compile the fragment shader */ - p = fragment_shader; - f = glCreateShader (GL_FRAGMENT_SHADER); - glShaderSource (f, 1, &p, NULL); - glCompileShader (f); - glGetShaderInfoLog (f, sizeof msg, NULL, msg); - printf ("fragment shader info: %s\n", msg); - - /* Create and link the shader program */ - program = glCreateProgram (); - glAttachShader (program, v); - glAttachShader (program, f); - glBindAttribLocation (program, 0, "position"); - glBindAttribLocation (program, 1, "normal"); - - glLinkProgram (program); - glGetProgramInfoLog (program, sizeof msg, NULL, msg); - printf ("info: %s\n", msg); - - /* Enable the shaders */ - glUseProgram (program); - - /* Get the locations of the uniforms so we can access them */ - ModelViewProjectionMatrix_location = - glGetUniformLocation (program, "ModelViewProjectionMatrix"); - NormalMatrix_location = - glGetUniformLocation (program, "NormalMatrix"); - LightSourcePosition_location = - glGetUniformLocation (program, "LightSourcePosition"); - MaterialColor_location = - glGetUniformLocation (program, "MaterialColor"); - - /* Set the LightSourcePosition uniform which is constant throughout - * the program */ - glUniform4fv (LightSourcePosition_location, 1, LightSourcePosition); - - /* make the gears */ - gear1 = create_gear (1.0, 4.0, 1.0, 20, 0.7); - gear2 = create_gear (0.5, 2.0, 2.0, 10, 0.7); - gear3 = create_gear (1.3, 2.0, 0.5, 10, 0.7); -} - -int -main (int argc, char **argv) -{ - Data data; - CoglOnscreen *onscreen; - CoglError *error = NULL; - GSource *cogl_source; - GMainLoop *loop; - CoglRenderer *renderer; - CoglDisplay *display; - - renderer = cogl_renderer_new (); - cogl_renderer_add_constraint (renderer, - COGL_RENDERER_CONSTRAINT_SUPPORTS_COGL_GLES2); - display = cogl_display_new (renderer, NULL); - data.ctx = cogl_context_new (display, NULL); - - onscreen = cogl_onscreen_new (data.ctx, 300, 300); - cogl_onscreen_show (onscreen); - data.fb = onscreen; - - data.gles2_ctx = cogl_gles2_context_new (data.ctx, &error); - if (!data.gles2_ctx) - g_error ("Failed to create GLES2 context: %s\n", error->message); - - /* Draw scene with GLES2 */ - if (!cogl_push_gles2_context (data.ctx, - data.gles2_ctx, - data.fb, - data.fb, - &error)) - { - g_error ("Failed to push gles2 context: %s\n", error->message); - } - - gears_reshape (cogl_framebuffer_get_width (data.fb), - cogl_framebuffer_get_height (data.fb)); - - /* Initialize the gears */ - gears_init(); - - cogl_pop_gles2_context (data.ctx); - - cogl_source = cogl_glib_source_new (data.ctx, G_PRIORITY_DEFAULT); - - g_source_attach (cogl_source, NULL); - - cogl_onscreen_add_frame_callback (COGL_ONSCREEN (data.fb), - frame_event_cb, - &data, - NULL); /* destroy notify */ - - g_idle_add (paint_cb, &data); - - data.timer = g_timer_new (); - data.frames = 0; - data.last_elapsed = 0; - - loop = g_main_loop_new (NULL, TRUE); - g_main_loop_run (loop); - - return 0; -} diff --git a/examples/cogl-hello.c b/examples/cogl-hello.c deleted file mode 100644 index 1387ab8a9..000000000 --- a/examples/cogl-hello.c +++ /dev/null @@ -1,123 +0,0 @@ -#include -#include -#include - -typedef struct _Data -{ - CoglContext *ctx; - CoglFramebuffer *fb; - CoglPrimitive *triangle; - CoglPipeline *pipeline; - - unsigned int redraw_idle; - CoglBool is_dirty; - CoglBool draw_ready; -} Data; - -static gboolean -paint_cb (void *user_data) -{ - Data *data = user_data; - - data->redraw_idle = 0; - data->is_dirty = FALSE; - data->draw_ready = FALSE; - - cogl_framebuffer_clear4f (data->fb, COGL_BUFFER_BIT_COLOR, 0, 0, 0, 1); - cogl_primitive_draw (data->triangle, - data->fb, - data->pipeline); - cogl_onscreen_swap_buffers (data->fb); - - return G_SOURCE_REMOVE; -} - -static void -maybe_redraw (Data *data) -{ - if (data->is_dirty && data->draw_ready && data->redraw_idle == 0) { - /* We'll draw on idle instead of drawing immediately so that - * if Cogl reports multiple dirty rectangles we won't - * redundantly draw multiple frames */ - data->redraw_idle = g_idle_add (paint_cb, data); - } -} - -static void -frame_event_cb (CoglOnscreen *onscreen, - CoglFrameEvent event, - CoglFrameInfo *info, - void *user_data) -{ - Data *data = user_data; - - if (event == COGL_FRAME_EVENT_SYNC) { - data->draw_ready = TRUE; - maybe_redraw (data); - } -} - -static void -dirty_cb (CoglOnscreen *onscreen, - const CoglOnscreenDirtyInfo *info, - void *user_data) -{ - Data *data = user_data; - - data->is_dirty = TRUE; - maybe_redraw (data); -} - -int -main (int argc, char **argv) -{ - Data data; - CoglOnscreen *onscreen; - CoglError *error = NULL; - CoglVertexP2C4 triangle_vertices[] = { - {0, 0.7, 0xff, 0x00, 0x00, 0xff}, - {-0.7, -0.7, 0x00, 0xff, 0x00, 0xff}, - {0.7, -0.7, 0x00, 0x00, 0xff, 0xff} - }; - GSource *cogl_source; - GMainLoop *loop; - - data.redraw_idle = 0; - data.is_dirty = FALSE; - data.draw_ready = TRUE; - - data.ctx = cogl_context_new (NULL, &error); - if (!data.ctx) { - fprintf (stderr, "Failed to create context: %s\n", error->message); - return 1; - } - - onscreen = cogl_onscreen_new (data.ctx, 640, 480); - cogl_onscreen_show (onscreen); - data.fb = onscreen; - - cogl_onscreen_set_resizable (onscreen, TRUE); - - data.triangle = cogl_primitive_new_p2c4 (data.ctx, - COGL_VERTICES_MODE_TRIANGLES, - 3, triangle_vertices); - data.pipeline = cogl_pipeline_new (data.ctx); - - cogl_source = cogl_glib_source_new (data.ctx, G_PRIORITY_DEFAULT); - - g_source_attach (cogl_source, NULL); - - cogl_onscreen_add_frame_callback (data.fb, - frame_event_cb, - &data, - NULL); /* destroy notify */ - cogl_onscreen_add_dirty_callback (data.fb, - dirty_cb, - &data, - NULL); /* destroy notify */ - - loop = g_main_loop_new (NULL, TRUE); - g_main_loop_run (loop); - - return 0; -} diff --git a/examples/cogl-info.c b/examples/cogl-info.c deleted file mode 100644 index 5d9482436..000000000 --- a/examples/cogl-info.c +++ /dev/null @@ -1,250 +0,0 @@ -#include -#include -#include - -struct { - CoglFeatureID feature; - const char *short_description; - const char *long_description; -} features[] = -{ - { - COGL_FEATURE_ID_TEXTURE_NPOT_BASIC, - "Non power of two textures (basic)", - "The hardware supports non power of two textures, but you also " - "need to check the COGL_FEATURE_ID_TEXTURE_NPOT_MIPMAP and " - "COGL_FEATURE_ID_TEXTURE_NPOT_REPEAT features to know if the " - "hardware supports npot texture mipmaps or repeat modes other " - "than COGL_RENDERER_PIPELINE_WRAP_MODE_CLAMP_TO_EDGE respectively." - }, - { - COGL_FEATURE_ID_TEXTURE_NPOT_MIPMAP, - "Non power of two textures (+ mipmap)", - "Mipmapping is supported in conjuntion with non power of two " - "textures." - }, - { - COGL_FEATURE_ID_TEXTURE_NPOT_REPEAT, - "Non power of two textures (+ repeat modes)", - "Repeat modes other than " - "COGL_RENDERER_PIPELINE_WRAP_MODE_CLAMP_TO_EDGE are supported by " - "the hardware in conjunction with non power of two textures." - }, - { - COGL_FEATURE_ID_TEXTURE_NPOT, - "Non power of two textures (fully featured)", - "Non power of two textures are supported by the hardware. This " - "is a equivalent to the COGL_FEATURE_ID_TEXTURE_NPOT_BASIC, " - "COGL_FEATURE_ID_TEXTURE_NPOT_MIPMAP and " - "COGL_FEATURE_ID_TEXTURE_NPOT_REPEAT features combined." - }, - { - COGL_FEATURE_ID_TEXTURE_RECTANGLE, - "Unnormalized coordinate, rectangle textures", - "Support for rectangular textures with non-normalized texture " - "coordinates." - }, - { - COGL_FEATURE_ID_TEXTURE_3D, - "3D texture support", - "3D texture support" - }, - { - COGL_FEATURE_ID_OFFSCREEN, - "Offscreen rendering support", - "Offscreen rendering support" - }, - { - COGL_FEATURE_ID_OFFSCREEN_MULTISAMPLE, - "Offscreen rendering with multisampling support", - "Offscreen rendering with multisampling support" - }, - { - COGL_FEATURE_ID_ONSCREEN_MULTIPLE, - "Multiple onscreen framebuffers supported", - "Multiple onscreen framebuffers supported" - }, - { - COGL_FEATURE_ID_GLSL, - "GLSL support", - "GLSL support" - }, - { - COGL_FEATURE_ID_ARBFP, - "ARBFP support", - "ARBFP support" - }, - { - COGL_FEATURE_ID_UNSIGNED_INT_INDICES, - "Unsigned integer indices", - "COGL_RENDERER_INDICES_TYPE_UNSIGNED_INT is supported in cogl_indices_new()." - }, - { - COGL_FEATURE_ID_DEPTH_RANGE, - "cogl_pipeline_set_depth_range() support", - "cogl_pipeline_set_depth_range() support", - }, - { - COGL_FEATURE_ID_POINT_SPRITE, - "Point sprite coordinates", - "cogl_pipeline_set_layer_point_sprite_coords_enabled() is supported" - }, - { - COGL_FEATURE_ID_MAP_BUFFER_FOR_READ, - "Mapping buffers for reading", - "Mapping buffers for reading" - }, - { - COGL_FEATURE_ID_MAP_BUFFER_FOR_WRITE, - "Mapping buffers for writing", - "Mapping buffers for writing" - }, - { - COGL_FEATURE_ID_MIRRORED_REPEAT, - "Mirrored repeat wrap modes", - "Mirrored repeat wrap modes" - }, - { - COGL_FEATURE_ID_GLES2_CONTEXT, - "GLES2 API integration supported", - "Support for creating a GLES2 context for using the GLES2 API in a " - "way that's integrated with Cogl." - }, - { - COGL_FEATURE_ID_DEPTH_TEXTURE, - "Depth Textures", - "CoglFramebuffers can be configured to render their depth buffer into " - "a texture" - }, - { - COGL_FEATURE_ID_PER_VERTEX_POINT_SIZE, - "Per-vertex point size", - "cogl_point_size_in can be used as an attribute to specify a per-vertex " - "point size" - } -}; - -static const char * -get_winsys_name_for_id (CoglWinsysID winsys_id) -{ - switch (winsys_id) - { - case COGL_WINSYS_ID_ANY: - g_return_val_if_reached ("ERROR"); - case COGL_WINSYS_ID_STUB: - return "Stub"; - case COGL_WINSYS_ID_GLX: - return "GLX"; - case COGL_WINSYS_ID_EGL_XLIB: - return "EGL + Xlib platform"; - case COGL_WINSYS_ID_EGL_KMS: - return "EGL + KMS platform"; - } - g_return_val_if_reached ("Unknown"); -} - -static void -feature_cb (CoglFeatureID feature, void *user_data) -{ - int i; - for (i = 0; i < sizeof(features) / sizeof(features[0]); i++) - { - if (features[i].feature == feature) - { - printf (" » %s\n", features[i].short_description); - return; - } - } - printf (" » Unknown feature %d\n", feature); -} - -typedef struct _OutputState -{ - int id; -} OutputState; - -static void -output_cb (CoglOutput *output, void *user_data) -{ - OutputState *state = user_data; - const char *order; - float refresh; - - printf (" Output%d:\n", state->id++); - printf (" » position = (%d, %d)\n", - cogl_output_get_x (output), - cogl_output_get_y (output)); - printf (" » resolution = %d x %d\n", - cogl_output_get_width (output), - cogl_output_get_height (output)); - printf (" » physical size = %dmm x %dmm\n", - cogl_output_get_mm_width (output), - cogl_output_get_mm_height (output)); - switch (cogl_output_get_subpixel_order (output)) - { - case COGL_SUBPIXEL_ORDER_NONE: - order = "non-standard"; - break; - case COGL_SUBPIXEL_ORDER_HORIZONTAL_RGB: - order = "horizontal,rgb"; - break; - case COGL_SUBPIXEL_ORDER_HORIZONTAL_BGR: - order = "horizontal,bgr"; - break; - case COGL_SUBPIXEL_ORDER_VERTICAL_RGB: - order = "vertical,rgb"; - break; - case COGL_SUBPIXEL_ORDER_VERTICAL_BGR: - order = "vertical,bgr"; - break; - default: - order = "unknown"; - break; - } - printf (" » sub pixel order = %s\n", order); - - refresh = cogl_output_get_refresh_rate (output); - if (refresh) - printf (" » refresh = %f Hz\n", refresh); - else - printf (" » refresh = unknown\n"); -} - -int -main (int argc, char **argv) -{ - CoglRenderer *renderer; - CoglDisplay *display; - CoglContext *ctx; - CoglError *error = NULL; - CoglWinsysID winsys_id; - const char *winsys_name; - OutputState output_state; - -#ifdef COGL_HAS_EMSCRIPTEN_SUPPORT - ctx = cogl_sdl_context_new (SDL_USEREVENT, &error); -#else - ctx = cogl_context_new (NULL, &error); -#endif - if (!ctx) { - fprintf (stderr, "Failed to create context: %s\n", error->message); - return 1; - } - - display = cogl_context_get_display (ctx); - renderer = cogl_display_get_renderer (display); - winsys_id = cogl_renderer_get_winsys_id (renderer); - winsys_name = get_winsys_name_for_id (winsys_id); - g_print ("Renderer: %s\n\n", winsys_name); - - g_print ("Features:\n"); - cogl_foreach_feature (ctx, feature_cb, NULL); - - g_print ("Outputs:\n"); - output_state.id = 0; - cogl_renderer_foreach_output (renderer, output_cb, &output_state); - if (output_state.id == 0) - printf (" Unknown\n"); - - return 0; -} diff --git a/examples/cogl-msaa.c b/examples/cogl-msaa.c deleted file mode 100644 index b5f6665b9..000000000 --- a/examples/cogl-msaa.c +++ /dev/null @@ -1,114 +0,0 @@ -#include -#include -#include - -int -main (int argc, char **argv) -{ - CoglOnscreenTemplate *onscreen_template; - CoglDisplay *display; - CoglContext *ctx; - CoglOnscreen *onscreen; - CoglFramebuffer *fb; - CoglError *error = NULL; - CoglVertexP2C4 triangle_vertices[] = { - {0, 0.7, 0xff, 0x00, 0x00, 0xff}, - {-0.7, -0.7, 0x00, 0xff, 0x00, 0xff}, - {0.7, -0.7, 0x00, 0x00, 0xff, 0xff} - }; - CoglPrimitive *triangle; - CoglTexture *tex; - CoglOffscreen *offscreen; - CoglFramebuffer *offscreen_fb; - CoglPipeline *pipeline; - - onscreen_template = cogl_onscreen_template_new (NULL); - cogl_onscreen_template_set_samples_per_pixel (onscreen_template, 4); - display = cogl_display_new (NULL, onscreen_template); - - if (!cogl_display_setup (display, &error)) - { - fprintf (stderr, "Platform doesn't support onscreen 4x msaa rendering: %s\n", - error->message); - return 1; - } - - ctx = cogl_context_new (display, &error); - if (!ctx) - { - fprintf (stderr, "Failed to create context: %s\n", error->message); - return 1; - } - - onscreen = cogl_onscreen_new (ctx, 640, 480); - fb = onscreen; - - cogl_framebuffer_set_samples_per_pixel (fb, 4); - - if (!cogl_framebuffer_allocate (fb, &error)) - { - fprintf (stderr, "Failed to allocate 4x msaa offscreen framebuffer, " - "disabling msaa for onscreen rendering: %s\n", error->message); - cogl_error_free (error); - cogl_framebuffer_set_samples_per_pixel (fb, 0); - - error = NULL; - if (!cogl_framebuffer_allocate (fb, &error)) - { - fprintf (stderr, "Failed to allocate framebuffer: %s\n", error->message); - return 1; - } - } - - cogl_onscreen_show (onscreen); - - tex = cogl_texture_2d_new_with_size (ctx, 320, 480); - offscreen = cogl_offscreen_new_with_texture (tex); - offscreen_fb = offscreen; - cogl_framebuffer_set_samples_per_pixel (offscreen_fb, 4); - if (!cogl_framebuffer_allocate (offscreen_fb, &error)) - { - cogl_error_free (error); - error = NULL; - fprintf (stderr, "Failed to allocate 4x msaa offscreen framebuffer, " - "disabling msaa for offscreen rendering"); - cogl_framebuffer_set_samples_per_pixel (offscreen_fb, 0); - } - - triangle = cogl_primitive_new_p2c4 (ctx, COGL_VERTICES_MODE_TRIANGLES, - 3, triangle_vertices); - pipeline = cogl_pipeline_new (ctx); - - for (;;) { - CoglPollFD *poll_fds; - int n_poll_fds; - int64_t timeout; - CoglPipeline *texture_pipeline; - - cogl_framebuffer_clear4f (fb, COGL_BUFFER_BIT_COLOR, 0, 0, 0, 1); - - cogl_framebuffer_push_matrix (fb); - cogl_framebuffer_scale (fb, 0.5, 1, 1); - cogl_framebuffer_translate (fb, -1, 0, 0); - cogl_primitive_draw (triangle, fb, pipeline); - cogl_framebuffer_pop_matrix (fb); - - cogl_primitive_draw (triangle, fb, pipeline); - cogl_framebuffer_resolve_samples (offscreen_fb); - - texture_pipeline = cogl_pipeline_new (ctx); - cogl_pipeline_set_layer_texture (texture_pipeline, 0, tex); - cogl_framebuffer_draw_rectangle (fb, texture_pipeline, 0, 1, 1, -1); - cogl_object_unref (texture_pipeline); - - cogl_onscreen_swap_buffers (onscreen); - - cogl_poll_renderer_get_info (cogl_context_get_renderer (ctx), - &poll_fds, &n_poll_fds, &timeout); - g_poll ((GPollFD *) poll_fds, n_poll_fds, 0); - cogl_poll_renderer_dispatch (cogl_context_get_renderer (ctx), - poll_fds, n_poll_fds); - } - - return 0; -} diff --git a/examples/cogl-point-sprites.c b/examples/cogl-point-sprites.c deleted file mode 100644 index 860d8fe78..000000000 --- a/examples/cogl-point-sprites.c +++ /dev/null @@ -1,323 +0,0 @@ -#include -#include -#include -#include -#include - -#define N_FIREWORKS 32 -/* Units per second per second */ -#define GRAVITY -1.5f - -#define N_SPARKS (N_FIREWORKS * 32) /* Must be a power of two */ -#define TIME_PER_SPARK 0.01f /* in seconds */ - -#define TEXTURE_SIZE 32 - -typedef struct -{ - uint8_t red, green, blue, alpha; -} Color; - -typedef struct -{ - float size; - float x, y; - float start_x, start_y; - Color color; - - /* Velocities are in units per second */ - float initial_x_velocity; - float initial_y_velocity; - - GTimer *timer; -} Firework; - -typedef struct -{ - float x, y; - Color color; - Color base_color; -} Spark; - -typedef struct -{ - Firework fireworks[N_FIREWORKS]; - - int next_spark_num; - Spark sparks[N_SPARKS]; - GTimer *last_spark_time; - - CoglContext *context; - CoglFramebuffer *fb; - CoglPipeline *pipeline; - CoglPrimitive *primitive; - CoglAttributeBuffer *attribute_buffer; -} Data; - -static CoglTexture * -generate_round_texture (CoglContext *context) -{ - uint8_t *p, *data; - int x, y; - CoglTexture2D *tex; - - p = data = g_malloc (TEXTURE_SIZE * TEXTURE_SIZE * 4); - - /* Generate a white circle which gets transparent towards the edges */ - for (y = 0; y < TEXTURE_SIZE; y++) - for (x = 0; x < TEXTURE_SIZE; x++) - { - int dx = x - TEXTURE_SIZE / 2; - int dy = y - TEXTURE_SIZE / 2; - float value = sqrtf (dx * dx + dy * dy) * 255.0 / (TEXTURE_SIZE / 2); - if (value > 255.0f) - value = 255.0f; - value = 255.0f - value; - *(p++) = value; - *(p++) = value; - *(p++) = value; - *(p++) = value; - } - - tex = cogl_texture_2d_new_from_data (context, - TEXTURE_SIZE, TEXTURE_SIZE, - COGL_PIXEL_FORMAT_RGBA_8888_PRE, - TEXTURE_SIZE * 4, - data, - NULL /* error */); - - g_free (data); - - return tex; -} - -static void -paint (Data *data) -{ - int i; - float diff_time; - - /* Update all of the firework's positions */ - for (i = 0; i < N_FIREWORKS; i++) - { - Firework *firework = data->fireworks + i; - - if ((fabsf (firework->x - firework->start_x) > 2.0f) || - firework->y < -1.0f) - { - firework->size = g_random_double_range (0.001f, 0.1f); - firework->start_x = 1.0f + firework->size; - firework->start_y = -1.0f; - firework->initial_x_velocity = g_random_double_range (-0.1f, -2.0f); - firework->initial_y_velocity = g_random_double_range (0.1f, 4.0f); - g_timer_reset (firework->timer); - - /* Pick a random color out of six */ - if (g_random_boolean ()) - { - memset (&firework->color, 0, sizeof (Color)); - ((uint8_t *) &firework->color)[g_random_int_range (0, 3)] = 255; - } - else - { - memset (&firework->color, 255, sizeof (Color)); - ((uint8_t *) &firework->color)[g_random_int_range (0, 3)] = 0; - } - firework->color.alpha = 255; - - /* Fire some of the fireworks from the other side */ - if (g_random_boolean ()) - { - firework->start_x = -firework->start_x; - firework->initial_x_velocity = -firework->initial_x_velocity; - } - } - - diff_time = g_timer_elapsed (firework->timer, NULL); - - firework->x = (firework->start_x + - firework->initial_x_velocity * diff_time); - - firework->y = ((firework->initial_y_velocity * diff_time + - 0.5f * GRAVITY * diff_time * diff_time) + - firework->start_y); - } - - diff_time = g_timer_elapsed (data->last_spark_time, NULL); - if (diff_time < 0.0f || diff_time >= TIME_PER_SPARK) - { - /* Add a new spark for each firework, overwriting the oldest ones */ - for (i = 0; i < N_FIREWORKS; i++) - { - Spark *spark = data->sparks + data->next_spark_num; - Firework *firework = data->fireworks + i; - - spark->x = (firework->x + - g_random_double_range (-firework->size / 2.0f, - firework->size / 2.0f)); - spark->y = (firework->y + - g_random_double_range (-firework->size / 2.0f, - firework->size / 2.0f)); - spark->base_color = firework->color; - - data->next_spark_num = (data->next_spark_num + 1) & (N_SPARKS - 1); - } - - /* Update the colour of each spark */ - for (i = 0; i < N_SPARKS; i++) - { - float color_value; - - /* First spark is the oldest */ - Spark *spark = data->sparks + ((data->next_spark_num + i) - & (N_SPARKS - 1)); - - color_value = i / (N_SPARKS - 1.0f); - spark->color.red = spark->base_color.red * color_value; - spark->color.green = spark->base_color.green * color_value; - spark->color.blue = spark->base_color.blue * color_value; - spark->color.alpha = 255.0f * color_value; - } - - g_timer_reset (data->last_spark_time); - } - - cogl_buffer_set_data (data->attribute_buffer, - 0, /* offset */ - data->sparks, - sizeof (data->sparks)); - - cogl_framebuffer_clear4f (data->fb, COGL_BUFFER_BIT_COLOR, 0, 0, 0, 1); - - cogl_primitive_draw (data->primitive, - data->fb, - data->pipeline); - - cogl_onscreen_swap_buffers (data->fb); -} - -static void -create_primitive (Data *data) -{ - CoglAttribute *attributes[2]; - int i; - - data->attribute_buffer = - cogl_attribute_buffer_new_with_size (data->context, - sizeof (data->sparks)); - cogl_buffer_set_update_hint (data->attribute_buffer, - COGL_BUFFER_UPDATE_HINT_DYNAMIC); - - attributes[0] = cogl_attribute_new (data->attribute_buffer, - "cogl_position_in", - sizeof (Spark), - G_STRUCT_OFFSET (Spark, x), - 2, /* n_components */ - COGL_ATTRIBUTE_TYPE_FLOAT); - attributes[1] = cogl_attribute_new (data->attribute_buffer, - "cogl_color_in", - sizeof (Spark), - G_STRUCT_OFFSET (Spark, color), - 4, /* n_components */ - COGL_ATTRIBUTE_TYPE_UNSIGNED_BYTE); - - data->primitive = - cogl_primitive_new_with_attributes (COGL_VERTICES_MODE_POINTS, - N_SPARKS, - attributes, - G_N_ELEMENTS (attributes)); - - for (i = 0; i < G_N_ELEMENTS (attributes); i++) - cogl_object_unref (attributes[i]); -} - -static void -frame_event_cb (CoglOnscreen *onscreen, - CoglFrameEvent event, - CoglFrameInfo *info, - void *user_data) -{ - Data *data = user_data; - - if (event == COGL_FRAME_EVENT_SYNC) - paint (data); -} - -int -main (int argc, char *argv[]) -{ - CoglTexture *tex; - CoglOnscreen *onscreen; - GSource *cogl_source; - GMainLoop *loop; - Data data; - int i; - - data.context = cogl_context_new (NULL, NULL); - - create_primitive (&data); - - data.pipeline = cogl_pipeline_new (data.context); - data.last_spark_time = g_timer_new (); - data.next_spark_num = 0; - cogl_pipeline_set_point_size (data.pipeline, TEXTURE_SIZE); - - tex = generate_round_texture (data.context); - cogl_pipeline_set_layer_texture (data.pipeline, 0, tex); - cogl_object_unref (tex); - - cogl_pipeline_set_layer_point_sprite_coords_enabled (data.pipeline, - 0, /* layer */ - TRUE, - NULL /* error */); - - for (i = 0; i < N_FIREWORKS; i++) - { - data.fireworks[i].x = -FLT_MAX; - data.fireworks[i].y = FLT_MAX; - data.fireworks[i].size = 0.0f; - data.fireworks[i].timer = g_timer_new (); - } - - for (i = 0; i < N_SPARKS; i++) - { - data.sparks[i].x = 2.0f; - data.sparks[i].y = 2.0f; - } - - onscreen = cogl_onscreen_new (data.context, 800, 600); - cogl_onscreen_show (onscreen); - data.fb = onscreen; - - cogl_source = cogl_glib_source_new (data.context, G_PRIORITY_DEFAULT); - - g_source_attach (cogl_source, NULL); - - cogl_onscreen_add_frame_callback (onscreen, - frame_event_cb, - &data, - NULL /* destroy notify */); - - loop = g_main_loop_new (NULL, TRUE); - - paint (&data); - - g_main_loop_run (loop); - - g_main_loop_unref (loop); - - g_source_destroy (cogl_source); - - cogl_object_unref (data.pipeline); - cogl_object_unref (data.attribute_buffer); - cogl_object_unref (data.primitive); - cogl_object_unref (onscreen); - cogl_object_unref (data.context); - - g_timer_destroy (data.last_spark_time); - - for (i = 0; i < N_FIREWORKS; i++) - g_timer_destroy (data.fireworks[i].timer); - - return 0; -} diff --git a/examples/cogl-stereo.c b/examples/cogl-stereo.c deleted file mode 100644 index 52723e13c..000000000 --- a/examples/cogl-stereo.c +++ /dev/null @@ -1,152 +0,0 @@ -#include -#include -#include - -typedef struct _Data -{ - CoglContext *ctx; - CoglFramebuffer *fb; - CoglPrimitive *left_triangle; - CoglPrimitive *right_triangle; - CoglPipeline *pipeline; - - unsigned int redraw_idle; - CoglBool is_dirty; - CoglBool draw_ready; -} Data; - -static gboolean -paint_cb (void *user_data) -{ - Data *data = user_data; - - data->redraw_idle = 0; - data->is_dirty = FALSE; - data->draw_ready = FALSE; - - cogl_framebuffer_set_stereo_mode (data->fb, COGL_STEREO_BOTH); - cogl_framebuffer_clear4f (data->fb, COGL_BUFFER_BIT_COLOR, 0, 0, 0, 1); - - cogl_framebuffer_set_stereo_mode (data->fb, COGL_STEREO_LEFT); - cogl_primitive_draw (data->left_triangle, - data->fb, - data->pipeline); - - if (cogl_framebuffer_get_is_stereo (data->fb)) - { - cogl_framebuffer_set_stereo_mode (data->fb, COGL_STEREO_RIGHT); - cogl_primitive_draw (data->right_triangle, - data->fb, - data->pipeline); - } - - cogl_onscreen_swap_buffers (data->fb); - - return G_SOURCE_REMOVE; -} - -static void -maybe_redraw (Data *data) -{ - if (data->is_dirty && data->draw_ready && data->redraw_idle == 0) { - /* We'll draw on idle instead of drawing immediately so that - * if Cogl reports multiple dirty rectangles we won't - * redundantly draw multiple frames */ - data->redraw_idle = g_idle_add (paint_cb, data); - } -} - -static void -frame_event_cb (CoglOnscreen *onscreen, - CoglFrameEvent event, - CoglFrameInfo *info, - void *user_data) -{ - Data *data = user_data; - - if (event == COGL_FRAME_EVENT_SYNC) { - data->draw_ready = TRUE; - maybe_redraw (data); - } -} - -static void -dirty_cb (CoglOnscreen *onscreen, - const CoglOnscreenDirtyInfo *info, - void *user_data) -{ - Data *data = user_data; - - data->is_dirty = TRUE; - maybe_redraw (data); -} - -int -main (int argc, char **argv) -{ - Data data; - CoglRenderer *renderer; - CoglOnscreenTemplate *onscreen_template; - CoglDisplay *display; - CoglOnscreen *onscreen; - CoglError *error = NULL; - CoglVertexP2C4 left_triangle_vertices[] = { - {0.05, 0.7, 0xff, 0x00, 0x00, 0xff}, - {-0.65, -0.7, 0x00, 0xff, 0x00, 0xff}, - {0.75, -0.7, 0x00, 0x00, 0xff, 0xff} - }; - CoglVertexP2C4 right_triangle_vertices[] = { - {-0.05, 0.7, 0xff, 0x00, 0x00, 0xff}, - {-0.75, -0.7, 0x00, 0xff, 0x00, 0xff}, - {0.65, -0.7, 0x00, 0x00, 0xff, 0xff} - }; - GSource *cogl_source; - GMainLoop *loop; - - data.redraw_idle = 0; - data.is_dirty = FALSE; - data.draw_ready = TRUE; - - renderer = cogl_renderer_new (); - onscreen_template = cogl_onscreen_template_new (NULL); - cogl_onscreen_template_set_stereo_enabled (onscreen_template, TRUE); - display = cogl_display_new (renderer, onscreen_template); - - data.ctx = cogl_context_new (display, &error); - if (!data.ctx) { - fprintf (stderr, "Failed to create stereo context: %s\n", error->message); - return 1; - } - - onscreen = cogl_onscreen_new (data.ctx, 640, 480); - cogl_onscreen_show (onscreen); - data.fb = onscreen; - - cogl_onscreen_set_resizable (onscreen, TRUE); - - data.left_triangle = cogl_primitive_new_p2c4 (data.ctx, - COGL_VERTICES_MODE_TRIANGLES, - 3, left_triangle_vertices); - data.right_triangle = cogl_primitive_new_p2c4 (data.ctx, - COGL_VERTICES_MODE_TRIANGLES, - 3, right_triangle_vertices); - data.pipeline = cogl_pipeline_new (data.ctx); - - cogl_source = cogl_glib_source_new (data.ctx, G_PRIORITY_DEFAULT); - - g_source_attach (cogl_source, NULL); - - cogl_onscreen_add_frame_callback (data.fb, - frame_event_cb, - &data, - NULL); /* destroy notify */ - cogl_onscreen_add_dirty_callback (data.fb, - dirty_cb, - &data, - NULL); /* destroy notify */ - - loop = g_main_loop_new (NULL, TRUE); - g_main_loop_run (loop); - - return 0; -} diff --git a/examples/cogl-x11-foreign.c b/examples/cogl-x11-foreign.c deleted file mode 100644 index 04d586fac..000000000 --- a/examples/cogl-x11-foreign.c +++ /dev/null @@ -1,203 +0,0 @@ -#include -#include -#include -#include - -#include -#include - -#define X11_FOREIGN_EVENT_MASK \ - (KeyPressMask | \ - KeyReleaseMask | \ - ButtonPressMask | \ - ButtonReleaseMask | \ - PointerMotionMask) - -static void -update_cogl_x11_event_mask (CoglOnscreen *onscreen, - uint32_t event_mask, - void *user_data) -{ - Display *xdpy = user_data; - XSetWindowAttributes attrs; - uint32_t xwin; - - attrs.event_mask = event_mask | X11_FOREIGN_EVENT_MASK; - xwin = cogl_x11_onscreen_get_window_xid (onscreen); - - XChangeWindowAttributes (xdpy, - (Window)xwin, - CWEventMask, - &attrs); -} - -static void -resize_handler (CoglOnscreen *onscreen, - int width, - int height, - void *user_data) -{ - CoglFramebuffer *fb = user_data; - cogl_framebuffer_set_viewport (fb, width / 4, height / 4, width / 2, height / 2); -} - -int -main (int argc, char **argv) -{ - Display *xdpy; - CoglRenderer *renderer; - CoglSwapChain *chain; - CoglOnscreenTemplate *onscreen_template; - CoglDisplay *display; - CoglContext *ctx; - CoglOnscreen *onscreen; - CoglFramebuffer *fb; - CoglPipeline *pipeline; - CoglError *error = NULL; - uint32_t visual; - XVisualInfo template, *xvisinfo; - int visinfos_count; - XSetWindowAttributes xattr; - unsigned long mask; - Window xwin; - CoglVertexP2C4 triangle_vertices[] = { - {0, 0.7, 0xff, 0x00, 0x00, 0xff}, - {-0.7, -0.7, 0x00, 0xff, 0x00, 0xff}, - {0.7, -0.7, 0x00, 0x00, 0xff, 0xff} - }; - CoglPrimitive *triangle; - - - /* Since we want to test external ownership of the X display, - * connect to X manually... */ - xdpy = XOpenDisplay (NULL); - if (!xdpy) - { - fprintf (stderr, "Failed to open X Display\n"); - return 1; - } - - /* Conceptually choose a GPU... */ - renderer = cogl_renderer_new (); - /* FIXME: This should conceptually be part of the configuration of - * a renderer. */ - cogl_xlib_renderer_set_foreign_display (renderer, xdpy); - if (!cogl_renderer_connect (renderer, &error)) - { - fprintf (stderr, "Failed to connect to a renderer: %s\n", - error->message); - } - - chain = cogl_swap_chain_new (); - cogl_swap_chain_set_has_alpha (chain, TRUE); - - /* Conceptually declare upfront the kinds of windows we anticipate - * creating so that when we configure the display pipeline we can avoid - * having an impedance miss-match between the format of windows and the - * format the display pipeline expects. */ - onscreen_template = cogl_onscreen_template_new (chain); - cogl_object_unref (chain); - - /* Conceptually setup a display pipeline */ - display = cogl_display_new (renderer, onscreen_template); - cogl_object_unref (renderer); - if (!cogl_display_setup (display, &error)) - { - fprintf (stderr, "Failed to setup a display pipeline: %s\n", - error->message); - return 1; - } - - ctx = cogl_context_new (display, &error); - if (!ctx) - { - fprintf (stderr, "Failed to create context: %s\n", error->message); - return 1; - } - - onscreen = cogl_onscreen_new (ctx, 640, 480); - - /* We want to test that Cogl can handle foreign X windows... */ - - visual = cogl_x11_onscreen_get_visual_xid (onscreen); - if (!visual) - { - fprintf (stderr, "Failed to query an X visual suitable for the " - "configured CoglOnscreen framebuffer\n"); - return 1; - } - - template.visualid = visual; - xvisinfo = XGetVisualInfo (xdpy, VisualIDMask, &template, &visinfos_count); - - /* window attributes */ - xattr.background_pixel = WhitePixel (xdpy, DefaultScreen (xdpy)); - xattr.border_pixel = 0; - xattr.colormap = XCreateColormap (xdpy, - DefaultRootWindow (xdpy), - xvisinfo->visual, - AllocNone); - mask = CWBorderPixel | CWColormap; - - xwin = XCreateWindow (xdpy, - DefaultRootWindow (xdpy), - 0, 0, - 800, 600, - 0, - xvisinfo->depth, - InputOutput, - xvisinfo->visual, - mask, &xattr); - - XFree (xvisinfo); - - cogl_x11_onscreen_set_foreign_window_xid (onscreen, xwin, - update_cogl_x11_event_mask, - xdpy); - - XMapWindow (xdpy, xwin); - - fb = onscreen; - - cogl_onscreen_set_resizable (onscreen, TRUE); - cogl_onscreen_add_resize_callback (onscreen, resize_handler, onscreen, NULL); - - triangle = cogl_primitive_new_p2c4 (ctx, COGL_VERTICES_MODE_TRIANGLES, - 3, triangle_vertices); - pipeline = cogl_pipeline_new (ctx); - for (;;) - { - CoglPollFD *poll_fds; - int n_poll_fds; - int64_t timeout; - - while (XPending (xdpy)) - { - XEvent event; - XNextEvent (xdpy, &event); - switch (event.type) - { - case KeyRelease: - case ButtonRelease: - return 0; - } - cogl_xlib_renderer_handle_event (renderer, &event); - } - - /* After forwarding native events directly to Cogl you should - * then allow Cogl to dispatch any corresponding event - * callbacks, such as resize notification callbacks... - */ - cogl_poll_renderer_get_info (cogl_context_get_renderer (ctx), - &poll_fds, &n_poll_fds, &timeout); - g_poll ((GPollFD *) poll_fds, n_poll_fds, 0); - cogl_poll_renderer_dispatch (cogl_context_get_renderer (ctx), - poll_fds, n_poll_fds); - - cogl_framebuffer_clear4f (fb, COGL_BUFFER_BIT_COLOR, 0, 0, 0, 1); - cogl_primitive_draw (triangle, fb, pipeline); - cogl_onscreen_swap_buffers (onscreen); - } - - return 0; -} diff --git a/examples/cogl-x11-tfp.c b/examples/cogl-x11-tfp.c deleted file mode 100644 index 6a0f81306..000000000 --- a/examples/cogl-x11-tfp.c +++ /dev/null @@ -1,408 +0,0 @@ -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#include -#include -#include - -#include - -#define X11_FOREIGN_EVENT_MASK \ - (KeyPressMask | \ - KeyReleaseMask | \ - ButtonPressMask | \ - ButtonReleaseMask | \ - PointerMotionMask) - -#define TFP_XWIN_WIDTH 200 -#define TFP_XWIN_HEIGHT 200 - -static pid_t gears_pid = 0; - -static void -spawn_gears (CoglBool stereo) -{ - pid_t pid = fork(); - - if (pid == 0) - execlp ("glxgears", "glxgears", - stereo ? "-stereo" : NULL, - NULL); - - gears_pid = pid; -} - -static XID -find_gears_toplevel (Display *xdpy, - Window window) -{ - Atom window_state = XInternAtom (xdpy, "WM_STATE", False); - Atom type; - int format; - unsigned long n_items; - unsigned long bytes_after; - unsigned char *data; - CoglBool result = FALSE; - - if (window == None) - window = DefaultRootWindow (xdpy); - - XGetWindowProperty (xdpy, window, window_state, - 0, G_MAXLONG, False, window_state, - &type, &format, &n_items, &bytes_after, &data); - - if (type == window_state) - { - XFree (data); - - XGetWindowProperty (xdpy, window, XA_WM_NAME, - 0, G_MAXLONG, False, XA_STRING, - &type, &format, &n_items, &bytes_after, &data); - - if (type == XA_STRING) - { - if (format == 8 && strcmp ((char *)data, "glxgears") == 0) - result = window; - - XFree (data); - } - } - else - { - Window root, parent; - Window *children; - unsigned int n_children; - unsigned int i; - - XQueryTree (xdpy, window, - &root, &parent, &children, &n_children); - - for (i = 0; i < n_children; i++) - { - result = find_gears_toplevel (xdpy, children[i]); - if (result != None) - break; - } - - XFree (children); - } - - return result; -} - -static void -kill_gears (void) -{ - kill (gears_pid, SIGTERM); -} - -static void -update_cogl_x11_event_mask (CoglOnscreen *onscreen, - uint32_t event_mask, - void *user_data) -{ - Display *xdpy = user_data; - XSetWindowAttributes attrs; - uint32_t xwin; - - attrs.event_mask = event_mask | X11_FOREIGN_EVENT_MASK; - xwin = cogl_x11_onscreen_get_window_xid (onscreen); - - XChangeWindowAttributes (xdpy, - (Window)xwin, - CWEventMask, - &attrs); -} - -int -main (int argc, char **argv) -{ - Display *xdpy; - int composite_error = 0, composite_event = 0; - CoglRenderer *renderer; - CoglSwapChain *chain; - CoglOnscreenTemplate *onscreen_template; - CoglDisplay *display; - CoglContext *ctx; - CoglOnscreen *onscreen; - CoglFramebuffer *fb; - CoglError *error = NULL; - uint32_t visual; - XVisualInfo template, *xvisinfo; - int visinfos_count; - XSetWindowAttributes xattr; - unsigned long mask; - Window xwin; - Atom atom_wm_protocols; - Atom atom_wm_delete_window; - int screen; - CoglBool gears = FALSE; - CoglBool stereo = FALSE; - Window tfp_xwin = None; - Pixmap pixmap; - CoglTexturePixmapX11 *tfp; - CoglTexture *right_texture = NULL; - GC gc = None; - int i; - - for (i = 1; i < argc; i++) - { - if (strcmp (argv[i], "--gears") == 0) - gears = TRUE; - else if (strcmp (argv[i], "--stereo") == 0) - stereo = TRUE; - else - { - g_printerr ("Usage: cogl-x11-tfp [--gears] [--stereo]\n"); - return 1; - } - } - - g_print ("NB: Don't use this example as a benchmark since there is " - "no synchonization between X window updates and onscreen " - "framebuffer updates!\n"); - - /* Since we want to test external ownership of the X display, - * connect to X manually... */ - xdpy = XOpenDisplay (NULL); - if (!xdpy) - { - fprintf (stderr, "Failed to open X Display\n"); - return 1; - } - - XSynchronize (xdpy, True); - - if (XCompositeQueryExtension (xdpy, &composite_event, &composite_error)) - { - int major = 0, minor = 0; - if (XCompositeQueryVersion (xdpy, &major, &minor)) - { - if (major != 0 || minor < 3) - g_error ("Missing XComposite extension >= 0.3"); - } - } - - if (gears) - { - spawn_gears (stereo); - while (TRUE) - { - tfp_xwin = find_gears_toplevel (xdpy, None); - if (tfp_xwin != None) - break; - - g_usleep (10000); - } - } - - /* Conceptually choose a GPU... */ - renderer = cogl_renderer_new (); - /* FIXME: This should conceptually be part of the configuration of - * a renderer. */ - cogl_xlib_renderer_set_foreign_display (renderer, xdpy); - if (!cogl_renderer_connect (renderer, &error)) - { - fprintf (stderr, "Failed to connect to a renderer: %s\n", - error->message); - } - - chain = cogl_swap_chain_new (); - cogl_swap_chain_set_has_alpha (chain, FALSE); - - /* Conceptually declare upfront the kinds of windows we anticipate - * creating so that when we configure the display pipeline we can avoid - * having an impedance miss-match between the format of windows and the - * format the display pipeline expects. */ - onscreen_template = cogl_onscreen_template_new (chain); - if (stereo) - cogl_onscreen_template_set_stereo_enabled (onscreen_template, TRUE); - cogl_object_unref (chain); - - /* Conceptually setup a display pipeline */ - display = cogl_display_new (renderer, onscreen_template); - cogl_object_unref (renderer); - if (!cogl_display_setup (display, &error)) - { - fprintf (stderr, "Failed to setup a display pipeline: %s\n", - error->message); - return 1; - } - - ctx = cogl_context_new (display, &error); - if (!ctx) - { - fprintf (stderr, "Failed to create context: %s\n", error->message); - return 1; - } - - onscreen = cogl_onscreen_new (ctx, 640, 480); - - /* We want to test that Cogl can handle foreign X windows... */ - - visual = cogl_x11_onscreen_get_visual_xid (onscreen); - if (!visual) - { - fprintf (stderr, "Failed to query an X visual suitable for the " - "configured CoglOnscreen framebuffer\n"); - return 1; - } - - template.visualid = visual; - xvisinfo = XGetVisualInfo (xdpy, VisualIDMask, &template, &visinfos_count); - - /* window attributes */ - xattr.background_pixel = WhitePixel (xdpy, DefaultScreen (xdpy)); - xattr.border_pixel = 0; - xattr.colormap = XCreateColormap (xdpy, - DefaultRootWindow (xdpy), - xvisinfo->visual, - AllocNone); - xattr.event_mask = StructureNotifyMask; - mask = CWBorderPixel | CWColormap | CWEventMask; - - xwin = XCreateWindow (xdpy, - DefaultRootWindow (xdpy), - 0, 0, - 800, 600, - 0, - xvisinfo->depth, - InputOutput, - xvisinfo->visual, - mask, &xattr); - - atom_wm_protocols = XInternAtom (xdpy, "WM_PROTOCOLS", False); - atom_wm_delete_window = XInternAtom (xdpy, "WM_DELETE_WINDOW", False); - XSetWMProtocols (xdpy, xwin, &atom_wm_delete_window, 1); - - XFree (xvisinfo); - - cogl_x11_onscreen_set_foreign_window_xid (onscreen, xwin, - update_cogl_x11_event_mask, - xdpy); - - XMapWindow (xdpy, xwin); - cogl_onscreen_show (onscreen); - - screen = DefaultScreen (xdpy); - - if (gears) - { - XCompositeRedirectWindow (xdpy, tfp_xwin, CompositeRedirectAutomatic); - } - else - { - XEvent xev; - - XCompositeRedirectSubwindows (xdpy, xwin, CompositeRedirectManual); - - tfp_xwin = XCreateSimpleWindow (xdpy, xwin, - 0, 0, TFP_XWIN_WIDTH, TFP_XWIN_HEIGHT, - 0, - WhitePixel (xdpy, screen), - WhitePixel (xdpy, screen)); - - XMapWindow (xdpy, tfp_xwin); - - while (TRUE) - { - XWindowEvent (xdpy, xwin, StructureNotifyMask, &xev); - - if (xev.xany.type == MapNotify) - break; - } - - gc = XCreateGC (xdpy, tfp_xwin, 0, NULL); - } - - pixmap = XCompositeNameWindowPixmap (xdpy, tfp_xwin); - - if (stereo) - { - tfp = cogl_texture_pixmap_x11_new_left (ctx, pixmap, TRUE, &error); - if (tfp) - right_texture = cogl_texture_pixmap_x11_new_right (tfp); - } - else - { - tfp = cogl_texture_pixmap_x11_new (ctx, pixmap, TRUE, &error); - } - - if (!tfp) - { - fprintf (stderr, "Failed to create CoglTexturePixmapX11: %s", - error->message); - return 1; - } - - fb = onscreen; - - for (;;) - { - unsigned long pixel; - CoglPipeline *pipeline; - - while (XPending (xdpy)) - { - XEvent event; - KeySym keysym; - XNextEvent (xdpy, &event); - switch (event.type) - { - case KeyRelease: - keysym = XLookupKeysym (&event.xkey, 0); - if (keysym == XK_q || keysym == XK_Q || keysym == XK_Escape) - goto out; - break; - case ClientMessage: - if (event.xclient.message_type == atom_wm_protocols && - event.xclient.data.l[0] == atom_wm_delete_window) - goto out; - break; - } - cogl_xlib_renderer_handle_event (renderer, &event); - } - - if (!gears) - { - pixel = - g_random_int_range (0, 255) << 24 | - g_random_int_range (0, 255) << 16 | - g_random_int_range (0, 255) << 8; - g_random_int_range (0, 255); - XSetForeground (xdpy, gc, pixel); - XFillRectangle (xdpy, tfp_xwin, gc, 0, 0, TFP_XWIN_WIDTH, TFP_XWIN_HEIGHT); - XFlush (xdpy); - } - - cogl_framebuffer_clear4f (fb, COGL_BUFFER_BIT_COLOR, 0, 0, 0, 1); - - pipeline = cogl_pipeline_new (ctx); - - cogl_framebuffer_set_stereo_mode (onscreen, COGL_STEREO_LEFT); - cogl_pipeline_set_layer_texture (pipeline, 0, tfp); - cogl_framebuffer_draw_rectangle (fb, pipeline, -0.8, 0.8, 0.8, -0.8); - - if (stereo) - { - cogl_framebuffer_set_stereo_mode (onscreen, COGL_STEREO_RIGHT); - cogl_pipeline_set_layer_texture (pipeline, 0, right_texture); - cogl_framebuffer_draw_rectangle (fb, pipeline, -0.8, 0.8, 0.8, -0.8); - } - - cogl_object_unref (pipeline); - - cogl_onscreen_swap_buffers (onscreen); - } - - out: - kill_gears (); - return 0; -} diff --git a/examples/cogland.c b/examples/cogland.c deleted file mode 100644 index f20821106..000000000 --- a/examples/cogland.c +++ /dev/null @@ -1,1224 +0,0 @@ -#include -#include -#include -#include -#include -#include -#include - -#include - -typedef struct _CoglandCompositor CoglandCompositor; - -typedef struct -{ - int x1, y1, x2, y2; -} CoglandRegion; - -typedef struct -{ - struct wl_resource *resource; - CoglandRegion region; -} CoglandSharedRegion; - -typedef struct -{ - struct wl_resource *resource; - struct wl_signal destroy_signal; - struct wl_listener destroy_listener; - - union - { - struct wl_shm_buffer *shm_buffer; - struct wl_buffer *legacy_buffer; - }; - - int32_t width, height; - uint32_t busy_count; -} CoglandBuffer; - -typedef struct -{ - CoglandBuffer *buffer; - struct wl_listener destroy_listener; -} CoglandBufferReference; - -typedef struct -{ - CoglandCompositor *compositor; - - struct wl_resource *resource; - int x; - int y; - CoglandBufferReference buffer_ref; - CoglTexture2D *texture; - - CoglBool has_shell_surface; - - struct wl_signal destroy_signal; - - /* All the pending state, that wl_surface.commit will apply. */ - struct - { - /* wl_surface.attach */ - CoglBool newly_attached; - CoglandBuffer *buffer; - struct wl_listener buffer_destroy_listener; - int32_t sx; - int32_t sy; - - /* wl_surface.damage */ - CoglandRegion damage; - - /* wl_surface.frame */ - struct wl_list frame_callback_list; - } pending; -} CoglandSurface; - -typedef struct -{ - CoglandSurface *surface; - struct wl_resource *resource; - struct wl_listener surface_destroy_listener; -} CoglandShellSurface; - -typedef struct -{ - uint32_t flags; - int width; - int height; - int refresh; -} CoglandMode; - -typedef struct -{ - struct wl_object wayland_output; - - int32_t x; - int32_t y; - int32_t width_mm; - int32_t height_mm; - - CoglOnscreen *onscreen; - - GList *modes; - -} CoglandOutput; - -typedef struct -{ - GSource source; - GPollFD pfd; - struct wl_display *display; -} WaylandEventSource; - -struct _CoglandCompositor -{ - struct wl_display *wayland_display; - struct wl_event_loop *wayland_loop; - - CoglContext *cogl_context; - - int virtual_width; - int virtual_height; - GList *outputs; - - struct wl_list frame_callbacks; - - CoglPrimitive *triangle; - CoglPipeline *triangle_pipeline; - - GSource *wayland_event_source; - - GList *surfaces; - - unsigned int redraw_idle; -}; - -static CoglBool option_multiple_outputs = FALSE; - -static GOptionEntry -options[] = - { - { - "multiple", 'm', 0, G_OPTION_ARG_NONE, &option_multiple_outputs, - "Split the compositor into four outputs", NULL - }, - { NULL, 0, 0, 0, NULL, NULL, NULL } - }; - -static CoglBool -process_arguments (int *argc, char ***argv, - GError **error) -{ - GOptionContext *context; - CoglBool ret; - GOptionGroup *group; - - group = g_option_group_new (NULL, /* name */ - NULL, /* description */ - NULL, /* help_description */ - NULL, /* user_data */ - NULL /* destroy notify */); - g_option_group_add_entries (group, options); - context = g_option_context_new ("- An example Wayland compositor using Cogl"); - g_option_context_set_main_group (context, group); - ret = g_option_context_parse (context, argc, argv, error); - g_option_context_free (context); - - if (ret && *argc > 1) - { - g_set_error (error, G_OPTION_ERROR, G_OPTION_ERROR_UNKNOWN_OPTION, - "Unknown option '%s'", (* argv)[1]); - ret = FALSE; - } - - return ret; -} - -static uint32_t -get_time (void) -{ - struct timeval tv; - gettimeofday (&tv, NULL); - return tv.tv_sec * 1000 + tv.tv_usec / 1000; -} - -static void -region_init (CoglandRegion *region) -{ - memset (region, 0, sizeof (*region)); -} - -static CoglBool -region_is_empty (const CoglandRegion *region) -{ - return region->x1 == region->x2 || region->y1 == region->y2; -} - -static void -region_add (CoglandRegion *region, - int x, - int y, - int w, - int h) -{ - if (region_is_empty (region)) - { - region->x1 = x; - region->y1 = y; - region->x2 = x + w; - region->y2 = y + h; - } - else - { - if (x < region->x1) - region->x1 = x; - if (y < region->y1) - region->y1 = y; - if (x + w > region->x2) - region->x2 = x + w; - if (y + h > region->y2) - region->y2 = y + h; - } -} - -static void -region_subtract (CoglandRegion *region, - int x, - int y, - int w, - int h) -{ - /* FIXME */ -} - -static CoglBool -wayland_event_source_prepare (GSource *base, int *timeout) -{ - WaylandEventSource *source = (WaylandEventSource *)base; - - *timeout = -1; - - wl_display_flush_clients (source->display); - - return FALSE; -} - -static CoglBool -wayland_event_source_check (GSource *base) -{ - WaylandEventSource *source = (WaylandEventSource *)base; - - return source->pfd.revents; -} - -static CoglBool -wayland_event_source_dispatch (GSource *base, - GSourceFunc callback, - void *data) -{ - WaylandEventSource *source = (WaylandEventSource *)base; - struct wl_event_loop *loop = wl_display_get_event_loop (source->display); - - wl_event_loop_dispatch (loop, 0); - - return TRUE; -} - -static GSourceFuncs wayland_event_source_funcs = -{ - wayland_event_source_prepare, - wayland_event_source_check, - wayland_event_source_dispatch, - NULL -}; - -static GSource * -wayland_event_source_new (struct wl_display *display) -{ - WaylandEventSource *source; - struct wl_event_loop *loop = - wl_display_get_event_loop (display); - - source = (WaylandEventSource *) g_source_new (&wayland_event_source_funcs, - sizeof (WaylandEventSource)); - source->display = display; - source->pfd.fd = wl_event_loop_get_fd (loop); - source->pfd.events = G_IO_IN | G_IO_ERR; - g_source_add_poll (&source->source, &source->pfd); - - return &source->source; -} - -static void -cogland_buffer_destroy_handler (struct wl_listener *listener, - void *data) -{ - CoglandBuffer *buffer = wl_container_of (listener, buffer, destroy_listener); - - wl_signal_emit (&buffer->destroy_signal, buffer); - g_slice_free (CoglandBuffer, buffer); -} - -static CoglandBuffer * -cogland_buffer_from_resource (struct wl_resource *resource) -{ - CoglandBuffer *buffer; - struct wl_listener *listener; - - listener = wl_resource_get_destroy_listener (resource, - cogland_buffer_destroy_handler); - - if (listener) - { - buffer = wl_container_of (listener, buffer, destroy_listener); - } - else - { - buffer = g_slice_new0 (CoglandBuffer); - - buffer->resource = resource; - wl_signal_init (&buffer->destroy_signal); - buffer->destroy_listener.notify = cogland_buffer_destroy_handler; - wl_resource_add_destroy_listener (resource, &buffer->destroy_listener); - } - - return buffer; -} - -static void -cogland_buffer_reference_handle_destroy (struct wl_listener *listener, - void *data) -{ - CoglandBufferReference *ref = - wl_container_of (listener, ref, destroy_listener); - - g_assert (data == ref->buffer); - - ref->buffer = NULL; -} - -static void -cogland_buffer_reference (CoglandBufferReference *ref, - CoglandBuffer *buffer) -{ - if (ref->buffer && buffer != ref->buffer) - { - ref->buffer->busy_count--; - - if (ref->buffer->busy_count == 0) - { - g_assert (wl_resource_get_client (ref->buffer->resource)); - wl_resource_queue_event (ref->buffer->resource, WL_BUFFER_RELEASE); - } - - wl_list_remove (&ref->destroy_listener.link); - } - - if (buffer && buffer != ref->buffer) - { - buffer->busy_count++; - wl_signal_add (&buffer->destroy_signal, &ref->destroy_listener); - } - - ref->buffer = buffer; - ref->destroy_listener.notify = cogland_buffer_reference_handle_destroy; -} - -typedef struct _CoglandFrameCallback -{ - struct wl_list link; - - /* Pointer back to the compositor */ - CoglandCompositor *compositor; - - struct wl_resource *resource; -} CoglandFrameCallback; - -static CoglBool -paint_cb (void *user_data) -{ - CoglandCompositor *compositor = user_data; - GList *l; - - for (l = compositor->outputs; l; l = l->next) - { - CoglandOutput *output = l->data; - CoglFramebuffer *fb = output->onscreen; - GList *l2; - - cogl_framebuffer_clear4f (fb, COGL_BUFFER_BIT_COLOR, 0, 0, 0, 1); - - cogl_primitive_draw (compositor->triangle, - fb, compositor->triangle_pipeline); - - for (l2 = compositor->surfaces; l2; l2 = l2->next) - { - CoglandSurface *surface = l2->data; - - if (surface->texture) - { - CoglTexture2D *texture = surface->texture; - CoglPipeline *pipeline = - cogl_pipeline_new (compositor->cogl_context); - cogl_pipeline_set_layer_texture (pipeline, 0, texture); - cogl_framebuffer_draw_rectangle (fb, pipeline, -1, 1, 1, -1); - cogl_object_unref (pipeline); - } - } - cogl_onscreen_swap_buffers (COGL_ONSCREEN (fb)); - } - - while (!wl_list_empty (&compositor->frame_callbacks)) - { - CoglandFrameCallback *callback = - wl_container_of (compositor->frame_callbacks.next, callback, link); - - wl_callback_send_done (callback->resource, get_time ()); - wl_resource_destroy (callback->resource); - } - - compositor->redraw_idle = 0; - - return G_SOURCE_REMOVE; -} - -static void -cogland_queue_redraw (CoglandCompositor *compositor) -{ - if (compositor->redraw_idle == 0) - compositor->redraw_idle = g_idle_add (paint_cb, compositor); -} - -static void -surface_damaged (CoglandSurface *surface, - int32_t x, - int32_t y, - int32_t width, - int32_t height) -{ - if (surface->buffer_ref.buffer && - surface->texture) - { - struct wl_shm_buffer *shm_buffer = - wl_shm_buffer_get (surface->buffer_ref.buffer->resource); - - if (shm_buffer) - cogl_wayland_texture_set_region_from_shm_buffer (surface->texture, - x, y, - width, - height, - shm_buffer, - x, y, - 0, /* level */ - NULL); - } - - cogland_queue_redraw (surface->compositor); -} - -static void -cogland_surface_destroy (struct wl_client *wayland_client, - struct wl_resource *wayland_resource) -{ - wl_resource_destroy (wayland_resource); -} - -static void -cogland_surface_attach (struct wl_client *wayland_client, - struct wl_resource *wayland_surface_resource, - struct wl_resource *wayland_buffer_resource, - int32_t sx, int32_t sy) -{ - CoglandSurface *surface = - wl_resource_get_user_data (wayland_surface_resource); - CoglandBuffer *buffer; - - if (wayland_buffer_resource) - buffer = cogland_buffer_from_resource (wayland_buffer_resource); - else - buffer = NULL; - - /* Attach without commit in between does not went wl_buffer.release */ - if (surface->pending.buffer) - wl_list_remove (&surface->pending.buffer_destroy_listener.link); - - surface->pending.sx = sx; - surface->pending.sy = sy; - surface->pending.buffer = buffer; - surface->pending.newly_attached = TRUE; - - if (buffer) - wl_signal_add (&buffer->destroy_signal, - &surface->pending.buffer_destroy_listener); -} - -static void -cogland_surface_damage (struct wl_client *client, - struct wl_resource *resource, - int32_t x, - int32_t y, - int32_t width, - int32_t height) -{ - CoglandSurface *surface = wl_resource_get_user_data (resource); - - region_add (&surface->pending.damage, x, y, width, height); -} - -static void -destroy_frame_callback (struct wl_resource *callback_resource) -{ - CoglandFrameCallback *callback = - wl_resource_get_user_data (callback_resource); - - wl_list_remove (&callback->link); - g_slice_free (CoglandFrameCallback, callback); -} - -static void -cogland_surface_frame (struct wl_client *client, - struct wl_resource *surface_resource, - uint32_t callback_id) -{ - CoglandFrameCallback *callback; - CoglandSurface *surface = wl_resource_get_user_data (surface_resource); - - callback = g_slice_new0 (CoglandFrameCallback); - callback->compositor = surface->compositor; - callback->resource = wl_client_add_object (client, - &wl_callback_interface, - NULL, /* no implementation */ - callback_id, - callback); - wl_resource_set_destructor (callback->resource, destroy_frame_callback); - - wl_list_insert (surface->pending.frame_callback_list.prev, &callback->link); -} - -static void -cogland_surface_set_opaque_region (struct wl_client *client, - struct wl_resource *resource, - struct wl_resource *region) -{ -} - -static void -cogland_surface_set_input_region (struct wl_client *client, - struct wl_resource *resource, - struct wl_resource *region) -{ -} - -static void -cogland_surface_commit (struct wl_client *client, - struct wl_resource *resource) -{ - CoglandSurface *surface = wl_resource_get_user_data (resource); - CoglandCompositor *compositor = surface->compositor; - - /* wl_surface.attach */ - if (surface->pending.newly_attached && - surface->buffer_ref.buffer != surface->pending.buffer) - { - CoglError *error = NULL; - - if (surface->texture) - { - cogl_object_unref (surface->texture); - surface->texture = NULL; - } - - cogland_buffer_reference (&surface->buffer_ref, surface->pending.buffer); - - if (surface->pending.buffer) - { - struct wl_resource *buffer_resource = - surface->pending.buffer->resource; - - surface->texture = - cogl_wayland_texture_2d_new_from_buffer (compositor->cogl_context, - buffer_resource, - &error); - - if (!surface->texture) - { - g_error ("Failed to create texture_2d from wayland buffer: %s", - error->message); - cogl_error_free (error); - } - } - } - if (surface->pending.buffer) - { - wl_list_remove (&surface->pending.buffer_destroy_listener.link); - surface->pending.buffer = NULL; - } - surface->pending.sx = 0; - surface->pending.sy = 0; - surface->pending.newly_attached = FALSE; - - /* wl_surface.damage */ - if (surface->buffer_ref.buffer && - surface->texture && - !region_is_empty (&surface->pending.damage)) - { - CoglandRegion *region = &surface->pending.damage; - CoglTexture *texture = surface->texture; - - if (region->x2 > cogl_texture_get_width (texture)) - region->x2 = cogl_texture_get_width (texture); - if (region->y2 > cogl_texture_get_height (texture)) - region->y2 = cogl_texture_get_height (texture); - if (region->x1 < 0) - region->x1 = 0; - if (region->y1 < 0) - region->y1 = 0; - - surface_damaged (surface, - region->x1, - region->y1, - region->x2 - region->x1, - region->y2 - region->y1); - } - region_init (&surface->pending.damage); - - /* wl_surface.frame */ - wl_list_insert_list (&compositor->frame_callbacks, - &surface->pending.frame_callback_list); - wl_list_init (&surface->pending.frame_callback_list); -} - -static void -cogland_surface_set_buffer_transform (struct wl_client *client, - struct wl_resource *resource, - int32_t transform) -{ -} - -const struct wl_surface_interface cogland_surface_interface = { - cogland_surface_destroy, - cogland_surface_attach, - cogland_surface_damage, - cogland_surface_frame, - cogland_surface_set_opaque_region, - cogland_surface_set_input_region, - cogland_surface_commit, - cogland_surface_set_buffer_transform -}; - -static void -cogland_surface_free (CoglandSurface *surface) -{ - CoglandCompositor *compositor = surface->compositor; - CoglandFrameCallback *cb, *next; - - wl_signal_emit (&surface->destroy_signal, &surface->resource); - - compositor->surfaces = g_list_remove (compositor->surfaces, surface); - - cogland_buffer_reference (&surface->buffer_ref, NULL); - if (surface->texture) - cogl_object_unref (surface->texture); - - if (surface->pending.buffer) - wl_list_remove (&surface->pending.buffer_destroy_listener.link); - - wl_list_for_each_safe (cb, next, - &surface->pending.frame_callback_list, link) - wl_resource_destroy (cb->resource); - - g_slice_free (CoglandSurface, surface); - - cogland_queue_redraw (compositor); -} - -static void -cogland_surface_resource_destroy_cb (struct wl_resource *resource) -{ - CoglandSurface *surface = wl_resource_get_user_data (resource); - cogland_surface_free (surface); -} - -static void -surface_handle_pending_buffer_destroy (struct wl_listener *listener, - void *data) -{ - CoglandSurface *surface = - wl_container_of (listener, surface, pending.buffer_destroy_listener); - - surface->pending.buffer = NULL; -} - -static void -cogland_compositor_create_surface (struct wl_client *wayland_client, - struct wl_resource *wayland_compositor_resource, - uint32_t id) -{ - CoglandCompositor *compositor = - wl_resource_get_user_data (wayland_compositor_resource); - CoglandSurface *surface = g_slice_new0 (CoglandSurface); - - surface->compositor = compositor; - - wl_signal_init (&surface->destroy_signal); - - surface->resource = wl_client_add_object (wayland_client, - &wl_surface_interface, - &cogland_surface_interface, - id, - surface); - wl_resource_set_destructor (surface->resource, - cogland_surface_resource_destroy_cb); - - surface->pending.buffer_destroy_listener.notify = - surface_handle_pending_buffer_destroy; - wl_list_init (&surface->pending.frame_callback_list); - region_init (&surface->pending.damage); - - compositor->surfaces = g_list_prepend (compositor->surfaces, - surface); -} - -static void -cogland_region_destroy (struct wl_client *client, - struct wl_resource *resource) -{ - wl_resource_destroy (resource); -} - -static void -cogland_region_add (struct wl_client *client, - struct wl_resource *resource, - int32_t x, - int32_t y, - int32_t width, - int32_t height) -{ - CoglandSharedRegion *shared_region = wl_resource_get_user_data (resource); - - region_add (&shared_region->region, x, y, width, height); -} - -static void -cogland_region_subtract (struct wl_client *client, - struct wl_resource *resource, - int32_t x, - int32_t y, - int32_t width, - int32_t height) -{ - CoglandSharedRegion *shared_region = wl_resource_get_user_data (resource); - - region_subtract (&shared_region->region, x, y, width, height); -} - -const struct wl_region_interface cogland_region_interface = { - cogland_region_destroy, - cogland_region_add, - cogland_region_subtract -}; - -static void -cogland_region_resource_destroy_cb (struct wl_resource *resource) -{ - CoglandSharedRegion *region = wl_resource_get_user_data (resource); - - g_slice_free (CoglandSharedRegion, region); -} - -static void -cogland_compositor_create_region (struct wl_client *wayland_client, - struct wl_resource *compositor_resource, - uint32_t id) -{ - CoglandSharedRegion *region = g_slice_new0 (CoglandSharedRegion); - - region->resource = wl_client_add_object (wayland_client, - &wl_region_interface, - &cogland_region_interface, - id, - region); - wl_resource_set_destructor (region->resource, - cogland_region_resource_destroy_cb); - - region_init (®ion->region); -} - -static void -bind_output (struct wl_client *client, - void *data, - uint32_t version, - uint32_t id) -{ - CoglandOutput *output = data; - struct wl_resource *resource = - wl_client_add_object (client, &wl_output_interface, NULL, id, data); - GList *l; - - wl_resource_post_event (resource, - WL_OUTPUT_GEOMETRY, - output->x, output->y, - output->width_mm, - output->height_mm, - 0, /* subpixel: unknown */ - "unknown", /* make */ - "unknown"); /* model */ - - for (l = output->modes; l; l = l->next) - { - CoglandMode *mode = l->data; - wl_resource_post_event (resource, - WL_OUTPUT_MODE, - mode->flags, - mode->width, - mode->height, - mode->refresh); - } -} - -static void -dirty_cb (CoglOnscreen *onscreen, - const CoglOnscreenDirtyInfo *info, - void *user_data) -{ - CoglandCompositor *compositor = user_data; - - cogland_queue_redraw (compositor); -} - -static void -cogland_compositor_create_output (CoglandCompositor *compositor, - int x, - int y, - int width_mm, - int height_mm) -{ - CoglandOutput *output = g_slice_new0 (CoglandOutput); - CoglFramebuffer *fb; - CoglError *error = NULL; - CoglandMode *mode; - - output->x = x; - output->y = y; - output->width_mm = width_mm; - output->height_mm = height_mm; - - output->wayland_output.interface = &wl_output_interface; - - wl_display_add_global (compositor->wayland_display, - &wl_output_interface, - output, - bind_output); - - output->onscreen = cogl_onscreen_new (compositor->cogl_context, - width_mm, height_mm); - /* Eventually there will be an implicit allocate on first use so this - * will become optional... */ - fb = output->onscreen; - if (!cogl_framebuffer_allocate (fb, &error)) - g_error ("Failed to allocate framebuffer: %s\n", error->message); - - cogl_onscreen_add_dirty_callback (output->onscreen, - dirty_cb, - compositor, - NULL /* destroy */); - - cogl_onscreen_show (output->onscreen); - cogl_framebuffer_set_viewport (fb, - -x, -y, - compositor->virtual_width, - compositor->virtual_height); - - mode = g_slice_new0 (CoglandMode); - mode->flags = 0; - mode->width = width_mm; - mode->height = height_mm; - mode->refresh = 60; - - output->modes = g_list_prepend (output->modes, mode); - - compositor->outputs = g_list_prepend (compositor->outputs, output); -} - -const static struct wl_compositor_interface cogland_compositor_interface = -{ - cogland_compositor_create_surface, - cogland_compositor_create_region -}; - -static void -compositor_bind (struct wl_client *client, - void *data, - uint32_t version, - uint32_t id) -{ - CoglandCompositor *compositor = data; - - wl_client_add_object (client, &wl_compositor_interface, - &cogland_compositor_interface, id, compositor); -} - -static void -shell_surface_pong (struct wl_client *client, - struct wl_resource *resource, - uint32_t serial) -{ -} - -static void -shell_surface_move (struct wl_client *client, - struct wl_resource *resource, - struct wl_resource *seat, - uint32_t serial) -{ -} - -static void -shell_surface_resize (struct wl_client *client, - struct wl_resource *resource, - struct wl_resource *seat, - uint32_t serial, - uint32_t edges) -{ -} - -static void -shell_surface_set_toplevel (struct wl_client *client, - struct wl_resource *resource) -{ -} - -static void -shell_surface_set_transient (struct wl_client *client, - struct wl_resource *resource, - struct wl_resource *parent, - int32_t x, - int32_t y, - uint32_t flags) -{ -} - -static void -shell_surface_set_fullscreen (struct wl_client *client, - struct wl_resource *resource, - uint32_t method, - uint32_t framerate, - struct wl_resource *output) -{ -} - -static void -shell_surface_set_popup (struct wl_client *client, - struct wl_resource *resource, - struct wl_resource *seat, - uint32_t serial, - struct wl_resource *parent, - int32_t x, - int32_t y, - uint32_t flags) -{ -} - -static void -shell_surface_set_maximized (struct wl_client *client, - struct wl_resource *resource, - struct wl_resource *output) -{ -} - -static void -shell_surface_set_title (struct wl_client *client, - struct wl_resource *resource, - const char *title) -{ -} - -static void -shell_surface_set_class (struct wl_client *client, - struct wl_resource *resource, - const char *class_) -{ -} - -static const struct wl_shell_surface_interface cogl_shell_surface_interface = -{ - shell_surface_pong, - shell_surface_move, - shell_surface_resize, - shell_surface_set_toplevel, - shell_surface_set_transient, - shell_surface_set_fullscreen, - shell_surface_set_popup, - shell_surface_set_maximized, - shell_surface_set_title, - shell_surface_set_class -}; - -static void -destroy_shell_surface (CoglandShellSurface *shell_surface) -{ - /* In case cleaning up a dead client destroys shell_surface first */ - if (shell_surface->surface) - { - wl_list_remove (&shell_surface->surface_destroy_listener.link); - shell_surface->surface->has_shell_surface = FALSE; - } - - g_free (shell_surface); -} - -static void -destroy_shell_surface_cb (struct wl_resource *resource) -{ - destroy_shell_surface (wl_resource_get_user_data (resource)); -} - -static void -shell_handle_surface_destroy (struct wl_listener *listener, - void *data) -{ - CoglandShellSurface *shell_surface = - wl_container_of (listener, shell_surface, surface_destroy_listener); - - shell_surface->surface->has_shell_surface = FALSE; - shell_surface->surface = NULL; - - if (shell_surface->resource) - wl_resource_destroy (shell_surface->resource); - else - destroy_shell_surface (shell_surface); -} - -static void -get_shell_surface (struct wl_client *client, - struct wl_resource *resource, - uint32_t id, - struct wl_resource *surface_resource) -{ - CoglandSurface *surface = wl_resource_get_user_data (surface_resource); - CoglandShellSurface *shell_surface; - - if (surface->has_shell_surface) - { - wl_resource_post_error (surface_resource, - WL_DISPLAY_ERROR_INVALID_OBJECT, - "wl_shell::get_shell_surface already requested"); - return; - } - - shell_surface = g_new0 (CoglandShellSurface, 1); - - shell_surface->surface = surface; - shell_surface->surface_destroy_listener.notify = - shell_handle_surface_destroy; - wl_signal_add (&surface->destroy_signal, - &shell_surface->surface_destroy_listener); - - surface->has_shell_surface = TRUE; - - shell_surface->resource = wl_client_add_object (client, - &wl_shell_surface_interface, - &cogl_shell_surface_interface, - id, - shell_surface); - wl_resource_set_destructor (shell_surface->resource, - destroy_shell_surface_cb); -} - -static const struct wl_shell_interface cogland_shell_interface = -{ - get_shell_surface -}; - -static void -bind_shell (struct wl_client *client, - void *data, - uint32_t version, - uint32_t id) -{ - wl_client_add_object (client, &wl_shell_interface, - &cogland_shell_interface, id, data); -} - -static CoglContext * -create_cogl_context (CoglandCompositor *compositor, - CoglBool use_egl_constraint, - CoglError **error) -{ - CoglRenderer *renderer = renderer = cogl_renderer_new (); - CoglDisplay *display; - CoglContext *context; - - if (use_egl_constraint) - cogl_renderer_add_constraint (renderer, COGL_RENDERER_CONSTRAINT_USES_EGL); - - if (!cogl_renderer_connect (renderer, error)) - { - cogl_object_unref (renderer); - return NULL; - } - - display = cogl_display_new (renderer, NULL); - cogl_wayland_display_set_compositor_display (display, - compositor->wayland_display); - - context = cogl_context_new (display, error); - - cogl_object_unref (renderer); - cogl_object_unref (display); - - return context; -} - -int -main (int argc, char **argv) -{ - CoglandCompositor compositor; - GMainLoop *loop; - CoglError *error = NULL; - GError *gerror = NULL; - CoglVertexP2C4 triangle_vertices[] = { - {0, 0.7, 0xff, 0x00, 0x00, 0xff}, - {-0.7, -0.7, 0x00, 0xff, 0x00, 0xff}, - {0.7, -0.7, 0x00, 0x00, 0xff, 0xff} - }; - GSource *cogl_source; - - if (!process_arguments (&argc, &argv, &gerror)) - { - fprintf (stderr, "%s\n", gerror->message); - return EXIT_FAILURE; - } - - memset (&compositor, 0, sizeof (compositor)); - - compositor.wayland_display = wl_display_create (); - if (compositor.wayland_display == NULL) - g_error ("failed to create wayland display"); - - wl_list_init (&compositor.frame_callbacks); - - if (!wl_display_add_global (compositor.wayland_display, - &wl_compositor_interface, - &compositor, - compositor_bind)) - g_error ("Failed to register wayland compositor object"); - - wl_display_init_shm (compositor.wayland_display); - - loop = g_main_loop_new (NULL, FALSE); - compositor.wayland_loop = - wl_display_get_event_loop (compositor.wayland_display); - compositor.wayland_event_source = - wayland_event_source_new (compositor.wayland_display); - g_source_attach (compositor.wayland_event_source, NULL); - - /* We want Cogl to use an EGL renderer because otherwise it won't - * set up the wl_drm object and only SHM buffers will work. */ - compositor.cogl_context = - create_cogl_context (&compositor, - TRUE /* use EGL constraint */, - &error); - if (compositor.cogl_context == NULL) - { - /* If we couldn't get an EGL context then try any type of - * context */ - cogl_error_free (error); - error = NULL; - - compositor.cogl_context = - create_cogl_context (&compositor, - FALSE, /* don't set EGL constraint */ - &error); - - if (compositor.cogl_context) - g_warning ("Failed to create context with EGL constraint, " - "falling back"); - else - g_error ("Failed to create a Cogl context: %s\n", error->message); - } - - compositor.virtual_width = 800; - compositor.virtual_height = 600; - - if (option_multiple_outputs) - { - int hw = compositor.virtual_width / 2; - int hh = compositor.virtual_height / 2; - /* Emulate compositing with multiple monitors... */ - cogland_compositor_create_output (&compositor, 0, 0, hw, hh); - cogland_compositor_create_output (&compositor, hw, 0, hw, hh); - cogland_compositor_create_output (&compositor, 0, hh, hw, hh); - cogland_compositor_create_output (&compositor, hw, hh, hw, hh); - } - else - { - cogland_compositor_create_output (&compositor, - 0, 0, - compositor.virtual_width, - compositor.virtual_height); - } - - if (wl_display_add_global (compositor.wayland_display, &wl_shell_interface, - &compositor, bind_shell) == NULL) - g_error ("Failed to register a global shell object"); - - if (wl_display_add_socket (compositor.wayland_display, "wayland-0")) - g_error ("Failed to create socket"); - - compositor.triangle = cogl_primitive_new_p2c4 (compositor.cogl_context, - COGL_VERTICES_MODE_TRIANGLES, - 3, triangle_vertices); - compositor.triangle_pipeline = cogl_pipeline_new (compositor.cogl_context); - - cogl_source = cogl_glib_source_new (compositor.cogl_context, - G_PRIORITY_DEFAULT); - - g_source_attach (cogl_source, NULL); - - g_main_loop_run (loop); - - return 0; -} diff --git a/examples/crate.jpg b/examples/crate.jpg deleted file mode 100644 index 2807459ffa4c08a37d23543635d301a8fd2c09be..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 171588 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�j}&?Y%B)gYvU-n`tdPirsYzm!Mwt=8 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 #X}+`T8%4qL=7uX`f7 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 dvn7)ei^95&B9