1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
|
/*
* Clutter-GStreamer.
*
* GStreamer integration library for Clutter.
*
* test-yuv-upload.c - Feed YUV frames to a cluttersink.
*
* Authored by Damien Lespiau <damien.lespiau@intel.com>
*
* Copyright (C) 2009 Intel Corporation
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
* Boston, MA 02111-1307, USA.
*/
#include <stdlib.h>
#include <string.h>
#include <glib/gprintf.h>
#include <clutter-gst/clutter-gst.h>
static gint opt_framerate = 30;
static gchar *opt_fourcc = "I420";
static GOptionEntry options[] =
{
{ "framerate",
'f', 0,
G_OPTION_ARG_INT,
&opt_framerate,
"Number of frames per second",
NULL },
{ "fourcc",
'o', 0,
G_OPTION_ARG_STRING,
&opt_fourcc,
"Fourcc of the wanted YUV format",
NULL },
{ NULL }
};
int
main (int argc, char *argv[])
{
GError *error = NULL;
gboolean result;
ClutterActor *stage;
ClutterActor *actor;
GstPipeline *pipeline;
GstElement *src;
GstElement *capsfilter;
GstElement *sink;
GstCaps *caps;
result = clutter_gst_init_with_args (&argc,
&argv,
" - Test YUV frames uploading",
options,
NULL,
&error);
if (error)
{
g_print ("%s\n", error->message);
g_error_free (error);
return EXIT_FAILURE;
}
stage = clutter_stage_new ();
clutter_actor_set_size (CLUTTER_ACTOR (stage), 320.0f, 240.0f);
/* Set up pipeline */
pipeline = GST_PIPELINE(gst_pipeline_new (NULL));
src = gst_element_factory_make ("videotestsrc", NULL);
capsfilter = gst_element_factory_make ("capsfilter", NULL);
sink = clutter_gst_create_video_sink ();
/* Video actor */
actor = g_object_new (CLUTTER_TYPE_ACTOR,
"content", g_object_new (CLUTTER_GST_TYPE_CONTENT,
"sink", sink,
NULL),
"width", clutter_actor_get_width (stage),
"height", clutter_actor_get_height (stage),
NULL);
/* make videotestsrc spit the format we want */
caps = gst_caps_new_simple ("video/x-raw",
"format", G_TYPE_STRING, opt_fourcc,
"framerate", GST_TYPE_FRACTION, opt_framerate, 1,
NULL);
g_object_set (capsfilter, "caps", caps, NULL);
g_printf ("%s: [caps] %s\n", __FILE__, gst_caps_to_string (caps));
gst_bin_add_many (GST_BIN (pipeline), src, capsfilter, sink, NULL);
result = gst_element_link_many (src, capsfilter, sink, NULL);
if (result == FALSE)
g_critical("Could not link elements");
gst_element_set_state (GST_ELEMENT(pipeline), GST_STATE_PLAYING);
clutter_actor_add_child (stage, actor);
clutter_actor_show (stage);
clutter_main();
return EXIT_SUCCESS;
}
|