| /* GStreamer |
| * Copyright (C) 2005 Wim Taymans <wim@fluendo.com> |
| * |
| * gstsegment.h: Header for GstSegment subsystem |
| * |
| * This library is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU Library 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 |
| * Library General Public License for more details. |
| * |
| * You should have received a copy of the GNU Library 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. |
| */ |
| |
| |
| #ifndef __GST_SEGMENT_H__ |
| #define __GST_SEGMENT_H__ |
| |
| #include <gst/gstevent.h> |
| #include <gst/gstformat.h> |
| |
| G_BEGIN_DECLS |
| |
| #define GST_TYPE_SEGMENT (gst_segment_get_type()) |
| |
| typedef struct _GstSegment GstSegment; |
| |
| /** |
| * GstSegment: |
| * @rate: the rate of the segment |
| * @abs_rate: absolute value of @rate |
| * @format: the format of the segment values |
| * @flags: flags for this segment |
| * @start: the start of the segment |
| * @stop: the stop of the segment |
| * @time: the stream time of the segment |
| * @accum: accumulated segment |
| * @last_stop: last known stop time |
| * @duration: total duration of segment |
| * @applied_rate: the already applied rate to the segment |
| * |
| * A helper structure that holds the configured region of |
| * interest in a media file. |
| */ |
| struct _GstSegment { |
| /*< public >*/ |
| gdouble rate; |
| gdouble abs_rate; |
| GstFormat format; |
| GstSeekFlags flags; |
| gint64 start; |
| gint64 stop; |
| gint64 time; |
| gint64 accum; |
| |
| gint64 last_stop; |
| gint64 duration; |
| |
| /* API added 0.10.6 */ |
| gdouble applied_rate; |
| |
| /*< private >*/ |
| /*gpointer _gst_reserved[GST_PADDING-2];*/ |
| guint8 _gst_reserved[(sizeof (gpointer) * GST_PADDING) - sizeof (gdouble)]; |
| }; |
| |
| GType gst_segment_get_type (void); |
| |
| GstSegment * gst_segment_new (void); |
| void gst_segment_free (GstSegment *segment); |
| |
| void gst_segment_init (GstSegment *segment, GstFormat format); |
| |
| void gst_segment_set_duration (GstSegment *segment, GstFormat format, gint64 duration); |
| void gst_segment_set_last_stop (GstSegment *segment, GstFormat format, gint64 position); |
| |
| void gst_segment_set_seek (GstSegment *segment, gdouble rate, |
| GstFormat format, GstSeekFlags flags, |
| GstSeekType cur_type, gint64 cur, |
| GstSeekType stop_type, gint64 stop, |
| gboolean *update); |
| |
| void gst_segment_set_newsegment (GstSegment *segment, gboolean update, gdouble rate, |
| GstFormat format, gint64 start, gint64 stop, gint64 time); |
| void gst_segment_set_newsegment_full (GstSegment *segment, gboolean update, gdouble rate, |
| gdouble applied_rate, GstFormat format, gint64 start, |
| gint64 stop, gint64 time); |
| |
| gint64 gst_segment_to_stream_time (GstSegment *segment, GstFormat format, gint64 position); |
| gint64 gst_segment_to_running_time (GstSegment *segment, GstFormat format, gint64 position); |
| |
| gboolean gst_segment_clip (GstSegment *segment, GstFormat format, gint64 start, |
| gint64 stop, gint64 *clip_start, gint64 *clip_stop); |
| |
| G_END_DECLS |
| |
| #endif /* __GST_SEGMENT_H__ */ |