mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-11-02 09:01:50 -05:00
examples: pause timer in PAUSED
This commit is contained in:
parent
df519ee3b3
commit
73cc2e054c
4 changed files with 8 additions and 12 deletions
|
|
@ -47,7 +47,6 @@ struct data {
|
||||||
SDL_Texture *texture;
|
SDL_Texture *texture;
|
||||||
|
|
||||||
struct pw_main_loop *loop;
|
struct pw_main_loop *loop;
|
||||||
struct spa_source *timer;
|
|
||||||
|
|
||||||
struct pw_context *context;
|
struct pw_context *context;
|
||||||
struct pw_core *core;
|
struct pw_core *core;
|
||||||
|
|
|
||||||
|
|
@ -234,7 +234,6 @@ static const struct pw_filter_events filter_events = {
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
struct data data = { 0, };
|
struct data data = { 0, };
|
||||||
const struct spa_pod *params[1];
|
|
||||||
|
|
||||||
pw_init(&argc, &argv);
|
pw_init(&argc, &argv);
|
||||||
|
|
||||||
|
|
@ -276,10 +275,8 @@ int main(int argc, char *argv[])
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* build the extra parameters to connect with. To connect, we can provide
|
/* Make a new DSP port. This will automatically set up the right
|
||||||
* a list of supported formats. We use a builder that writes the param
|
* parameters for the port */
|
||||||
* object to the stack. */
|
|
||||||
|
|
||||||
data.in_port = pw_filter_add_port(data.filter,
|
data.in_port = pw_filter_add_port(data.filter,
|
||||||
PW_DIRECTION_INPUT,
|
PW_DIRECTION_INPUT,
|
||||||
PW_FILTER_PORT_FLAG_MAP_BUFFERS,
|
PW_FILTER_PORT_FLAG_MAP_BUFFERS,
|
||||||
|
|
@ -288,7 +285,7 @@ int main(int argc, char *argv[])
|
||||||
PW_KEY_FORMAT_DSP, "32 bit float RGBA video",
|
PW_KEY_FORMAT_DSP, "32 bit float RGBA video",
|
||||||
PW_KEY_PORT_NAME, "input",
|
PW_KEY_PORT_NAME, "input",
|
||||||
NULL),
|
NULL),
|
||||||
params, 1);
|
NULL, 0);
|
||||||
|
|
||||||
pw_filter_connect(data.filter,
|
pw_filter_connect(data.filter,
|
||||||
0,
|
0,
|
||||||
|
|
|
||||||
|
|
@ -190,6 +190,8 @@ static void on_stream_state_changed(void *_data, enum pw_stream_state old, enum
|
||||||
switch (state) {
|
switch (state) {
|
||||||
case PW_STREAM_STATE_PAUSED:
|
case PW_STREAM_STATE_PAUSED:
|
||||||
printf("node id: %d\n", pw_stream_get_node_id(data->stream));
|
printf("node id: %d\n", pw_stream_get_node_id(data->stream));
|
||||||
|
pw_loop_update_timer(pw_main_loop_get_loop(data->loop),
|
||||||
|
data->timer, NULL, NULL, false);
|
||||||
break;
|
break;
|
||||||
case PW_STREAM_STATE_STREAMING:
|
case PW_STREAM_STATE_STREAMING:
|
||||||
{
|
{
|
||||||
|
|
@ -205,8 +207,6 @@ static void on_stream_state_changed(void *_data, enum pw_stream_state old, enum
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
pw_loop_update_timer(pw_main_loop_get_loop(data->loop),
|
|
||||||
data->timer, NULL, NULL, false);
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -192,6 +192,8 @@ static void on_stream_state_changed(void *_data, enum pw_stream_state old, enum
|
||||||
|
|
||||||
case PW_STREAM_STATE_PAUSED:
|
case PW_STREAM_STATE_PAUSED:
|
||||||
printf("node id: %d\n", pw_stream_get_node_id(data->stream));
|
printf("node id: %d\n", pw_stream_get_node_id(data->stream));
|
||||||
|
pw_loop_update_timer(pw_main_loop_get_loop(data->loop),
|
||||||
|
data->timer, NULL, NULL, false);
|
||||||
break;
|
break;
|
||||||
case PW_STREAM_STATE_STREAMING:
|
case PW_STREAM_STATE_STREAMING:
|
||||||
{
|
{
|
||||||
|
|
@ -207,8 +209,6 @@ static void on_stream_state_changed(void *_data, enum pw_stream_state old, enum
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
pw_loop_update_timer(pw_main_loop_get_loop(data->loop),
|
|
||||||
data->timer, NULL, NULL, false);
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -302,7 +302,7 @@ int main(int argc, char *argv[])
|
||||||
&SPA_RECTANGLE(320, 240),
|
&SPA_RECTANGLE(320, 240),
|
||||||
&SPA_RECTANGLE(1, 1),
|
&SPA_RECTANGLE(1, 1),
|
||||||
&SPA_RECTANGLE(4096, 4096)),
|
&SPA_RECTANGLE(4096, 4096)),
|
||||||
SPA_FORMAT_VIDEO_framerate, SPA_POD_Fraction(&SPA_FRACTION(25, 1)));
|
SPA_FORMAT_VIDEO_framerate, SPA_POD_Fraction(&SPA_FRACTION(25, 1)));
|
||||||
|
|
||||||
pw_stream_add_listener(data.stream,
|
pw_stream_add_listener(data.stream,
|
||||||
&data.stream_listener,
|
&data.stream_listener,
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue