[FFmpeg-cvslog] r18303 - trunk/libavcodec/pixdesc.h
stefano
subversion
Wed Apr 1 23:07:50 CEST 2009
Author: stefano
Date: Wed Apr 1 23:07:49 2009
New Revision: 18303
Log:
Extend read_line() to make it take a read_pal_component parameter.
Modified:
trunk/libavcodec/pixdesc.h
Modified: trunk/libavcodec/pixdesc.h
==============================================================================
--- trunk/libavcodec/pixdesc.h Wed Apr 1 11:11:32 2009 (r18302)
+++ trunk/libavcodec/pixdesc.h Wed Apr 1 23:07:49 2009 (r18303)
@@ -94,8 +94,13 @@ extern const AVPixFmtDescriptor av_pix_f
* @param y the vertical coordinate of the first pixel to read
* @param w the width of the line to read, that is the number of
* values to write to \p dst
+ * @param read_pal_component if not zero and the format is a paletted
+ * format writes to \p dst the values corresponding to the palette
+ * component \p c in data[1], rather than the palette indexes in
+ * data[0]. The behavior is undefined if the format is not paletted.
*/
-static inline void read_line(uint16_t *dst, const uint8_t *data[4], const int linesize[4], const AVPixFmtDescriptor *desc, int x, int y, int c, int w)
+static inline void read_line(uint16_t *dst, const uint8_t *data[4], const int linesize[4],
+ const AVPixFmtDescriptor *desc, int x, int y, int c, int w, int read_pal_component)
{
AVComponentDescriptor comp= desc->comp[c];
int plane= comp.plane;
@@ -112,7 +117,7 @@ static inline void read_line(uint16_t *d
while(w--){
int val = show_bits(&gb, depth);
- if(flags & PIX_FMT_PAL)
+ if(read_pal_component)
val= data[1][4*val + c];
skip_bits(&gb, step);
*dst++= val;
@@ -125,7 +130,7 @@ static inline void read_line(uint16_t *d
if(flags & PIX_FMT_BE) val= AV_RB16(p);
else val= AV_RL16(p);
val = (val>>shift) & mask;
- if(flags & PIX_FMT_PAL)
+ if(read_pal_component)
val= data[1][4*val + c];
p+= step;
*dst++= val;
More information about the ffmpeg-cvslog
mailing list