mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-02 14:36:41 +00:00
ext/libpng/gstpngenc.*: Add compression level property (#163323).
Original commit message from CVS: Reviewed by: Ronald S. Bultje <rbultje@ronald.bitfreak.net> * ext/libpng/gstpngenc.c: (gst_pngenc_class_init), (gst_pngenc_init), (gst_pngenc_chain), (gst_pngenc_get_property), (gst_pngenc_set_property): * ext/libpng/gstpngenc.h: Add compression level property (#163323).
This commit is contained in:
parent
741360c638
commit
1f19f8e63c
3 changed files with 29 additions and 2 deletions
10
ChangeLog
10
ChangeLog
|
@ -1,3 +1,13 @@
|
||||||
|
2005-01-09 Gergely Nagy <algernon@bonehunter.rulez.org>
|
||||||
|
|
||||||
|
Reviewed by: Ronald S. Bultje <rbultje@ronald.bitfreak.net>
|
||||||
|
|
||||||
|
* ext/libpng/gstpngenc.c: (gst_pngenc_class_init),
|
||||||
|
(gst_pngenc_init), (gst_pngenc_chain), (gst_pngenc_get_property),
|
||||||
|
(gst_pngenc_set_property):
|
||||||
|
* ext/libpng/gstpngenc.h:
|
||||||
|
Add compression level property (#163323).
|
||||||
|
|
||||||
2005-01-09 Ronald S. Bultje <rbultje@ronald.bitfreak.net>
|
2005-01-09 Ronald S. Bultje <rbultje@ronald.bitfreak.net>
|
||||||
|
|
||||||
* configure.ac:
|
* configure.ac:
|
||||||
|
|
|
@ -23,6 +23,7 @@
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
#include "gstpngenc.h"
|
#include "gstpngenc.h"
|
||||||
#include <gst/video/video.h>
|
#include <gst/video/video.h>
|
||||||
|
#include <zlib.h>
|
||||||
|
|
||||||
#define MAX_HEIGHT 4096
|
#define MAX_HEIGHT 4096
|
||||||
|
|
||||||
|
@ -48,7 +49,8 @@ enum
|
||||||
{
|
{
|
||||||
ARG_0,
|
ARG_0,
|
||||||
ARG_SNAPSHOT,
|
ARG_SNAPSHOT,
|
||||||
ARG_NEWMEDIA
|
ARG_NEWMEDIA,
|
||||||
|
ARG_COMPRESSION_LEVEL
|
||||||
};
|
};
|
||||||
|
|
||||||
static void gst_pngenc_base_init (gpointer g_class);
|
static void gst_pngenc_base_init (gpointer g_class);
|
||||||
|
@ -149,6 +151,13 @@ gst_pngenc_class_init (GstPngEncClass * klass)
|
||||||
"Send new media discontinuity after encoding each frame",
|
"Send new media discontinuity after encoding each frame",
|
||||||
FALSE, (GParamFlags) G_PARAM_READWRITE));
|
FALSE, (GParamFlags) G_PARAM_READWRITE));
|
||||||
|
|
||||||
|
g_object_class_install_property
|
||||||
|
(gobject_class, ARG_COMPRESSION_LEVEL,
|
||||||
|
g_param_spec_uint ("compression-level", "compression-level",
|
||||||
|
"PNG compression level",
|
||||||
|
Z_NO_COMPRESSION, Z_BEST_COMPRESSION,
|
||||||
|
6, (GParamFlags) G_PARAM_READWRITE));
|
||||||
|
|
||||||
gstelement_class->get_property = gst_pngenc_get_property;
|
gstelement_class->get_property = gst_pngenc_get_property;
|
||||||
gstelement_class->set_property = gst_pngenc_set_property;
|
gstelement_class->set_property = gst_pngenc_set_property;
|
||||||
}
|
}
|
||||||
|
@ -199,6 +208,7 @@ gst_pngenc_init (GstPngEnc * pngenc)
|
||||||
|
|
||||||
pngenc->snapshot = DEFAULT_SNAPSHOT;
|
pngenc->snapshot = DEFAULT_SNAPSHOT;
|
||||||
pngenc->newmedia = FALSE;
|
pngenc->newmedia = FALSE;
|
||||||
|
pngenc->compression_level = 6;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -281,7 +291,7 @@ gst_pngenc_chain (GstPad * pad, GstData * _data)
|
||||||
|
|
||||||
png_set_filter (pngenc->png_struct_ptr, 0,
|
png_set_filter (pngenc->png_struct_ptr, 0,
|
||||||
PNG_FILTER_NONE | PNG_FILTER_VALUE_NONE);
|
PNG_FILTER_NONE | PNG_FILTER_VALUE_NONE);
|
||||||
png_set_compression_level (pngenc->png_struct_ptr, 9);
|
png_set_compression_level (pngenc->png_struct_ptr, pngenc->compression_level);
|
||||||
|
|
||||||
png_set_IHDR (pngenc->png_struct_ptr,
|
png_set_IHDR (pngenc->png_struct_ptr,
|
||||||
pngenc->png_info_ptr,
|
pngenc->png_info_ptr,
|
||||||
|
@ -345,6 +355,9 @@ gst_pngenc_get_property (GObject * object,
|
||||||
case ARG_NEWMEDIA:
|
case ARG_NEWMEDIA:
|
||||||
g_value_set_boolean (value, pngenc->newmedia);
|
g_value_set_boolean (value, pngenc->newmedia);
|
||||||
break;
|
break;
|
||||||
|
case ARG_COMPRESSION_LEVEL:
|
||||||
|
g_value_set_uint (value, pngenc->compression_level);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
break;
|
break;
|
||||||
|
@ -367,6 +380,9 @@ gst_pngenc_set_property (GObject * object,
|
||||||
case ARG_NEWMEDIA:
|
case ARG_NEWMEDIA:
|
||||||
pngenc->newmedia = g_value_get_boolean (value);
|
pngenc->newmedia = g_value_get_boolean (value);
|
||||||
break;
|
break;
|
||||||
|
case ARG_COMPRESSION_LEVEL:
|
||||||
|
pngenc->compression_level = g_value_get_uint (value);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -51,6 +51,7 @@ struct _GstPngEnc
|
||||||
gint width;
|
gint width;
|
||||||
gint height;
|
gint height;
|
||||||
gint bpp;
|
gint bpp;
|
||||||
|
guint compression_level;
|
||||||
|
|
||||||
gboolean snapshot;
|
gboolean snapshot;
|
||||||
gboolean newmedia;
|
gboolean newmedia;
|
||||||
|
|
Loading…
Reference in a new issue