mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-02-28 17:51:05 +00:00
palette to bgr24
Originally committed as revision 2698 to svn://svn.mplayerhq.hu/mplayer/trunk/postproc
This commit is contained in:
parent
fcfbc150aa
commit
9ce6584e49
@ -181,6 +181,27 @@ void palette8torgb32(uint8_t *src, uint8_t *dst, int src_size, uint8_t *palette)
|
|||||||
((uint32_t *)dst)[i] = ((uint32_t *)palette)[ src[i] ];
|
((uint32_t *)dst)[i] = ((uint32_t *)palette)[ src[i] ];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Pallete is assumed to contain bgr32
|
||||||
|
*/
|
||||||
|
void palette8torgb24(uint8_t *src, uint8_t *dst, int src_size, uint8_t *palette)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
/*
|
||||||
|
writes 1 byte o much and might cause alignment issues on some architectures?
|
||||||
|
for(i=0; i<src_size; i++)
|
||||||
|
((uint32_t *)(&dst[i*3])) = ((uint32_t *)palette)[ src[i] ];
|
||||||
|
*/
|
||||||
|
for(i=0; i<src_size; i++)
|
||||||
|
{
|
||||||
|
//FIXME slow?
|
||||||
|
dst[0]= palette[ src[i]*4+0 ];
|
||||||
|
dst[1]= palette[ src[i]*4+1 ];
|
||||||
|
dst[2]= palette[ src[i]*4+2 ];
|
||||||
|
dst+= 3;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void rgb32to16(uint8_t *src, uint8_t *dst, int src_size)
|
void rgb32to16(uint8_t *src, uint8_t *dst, int src_size)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
@ -226,4 +247,4 @@ void palette8torgb15(uint8_t *src, uint8_t *dst, int src_size, uint8_t *palette)
|
|||||||
int i;
|
int i;
|
||||||
for(i=0; i<src_size; i++)
|
for(i=0; i<src_size; i++)
|
||||||
((uint16_t *)dst)[i] = ((uint16_t *)palette)[ src[i] ];
|
((uint16_t *)dst)[i] = ((uint16_t *)palette)[ src[i] ];
|
||||||
}
|
}
|
||||||
|
@ -16,6 +16,6 @@ void rgb32to15(uint8_t *src, uint8_t *dst, int src_size);
|
|||||||
void palette8torgb32(uint8_t *src, uint8_t *dst, int src_size, uint8_t *palette);
|
void palette8torgb32(uint8_t *src, uint8_t *dst, int src_size, uint8_t *palette);
|
||||||
void palette8torgb16(uint8_t *src, uint8_t *dst, int src_size, uint8_t *palette);
|
void palette8torgb16(uint8_t *src, uint8_t *dst, int src_size, uint8_t *palette);
|
||||||
void palette8torgb15(uint8_t *src, uint8_t *dst, int src_size, uint8_t *palette);
|
void palette8torgb15(uint8_t *src, uint8_t *dst, int src_size, uint8_t *palette);
|
||||||
|
void palette8torgb24(uint8_t *src, uint8_t *dst, int src_size, uint8_t *palette);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -181,6 +181,27 @@ void palette8torgb32(uint8_t *src, uint8_t *dst, int src_size, uint8_t *palette)
|
|||||||
((uint32_t *)dst)[i] = ((uint32_t *)palette)[ src[i] ];
|
((uint32_t *)dst)[i] = ((uint32_t *)palette)[ src[i] ];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Pallete is assumed to contain bgr32
|
||||||
|
*/
|
||||||
|
void palette8torgb24(uint8_t *src, uint8_t *dst, int src_size, uint8_t *palette)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
/*
|
||||||
|
writes 1 byte o much and might cause alignment issues on some architectures?
|
||||||
|
for(i=0; i<src_size; i++)
|
||||||
|
((uint32_t *)(&dst[i*3])) = ((uint32_t *)palette)[ src[i] ];
|
||||||
|
*/
|
||||||
|
for(i=0; i<src_size; i++)
|
||||||
|
{
|
||||||
|
//FIXME slow?
|
||||||
|
dst[0]= palette[ src[i]*4+0 ];
|
||||||
|
dst[1]= palette[ src[i]*4+1 ];
|
||||||
|
dst[2]= palette[ src[i]*4+2 ];
|
||||||
|
dst+= 3;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void rgb32to16(uint8_t *src, uint8_t *dst, int src_size)
|
void rgb32to16(uint8_t *src, uint8_t *dst, int src_size)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
@ -226,4 +247,4 @@ void palette8torgb15(uint8_t *src, uint8_t *dst, int src_size, uint8_t *palette)
|
|||||||
int i;
|
int i;
|
||||||
for(i=0; i<src_size; i++)
|
for(i=0; i<src_size; i++)
|
||||||
((uint16_t *)dst)[i] = ((uint16_t *)palette)[ src[i] ];
|
((uint16_t *)dst)[i] = ((uint16_t *)palette)[ src[i] ];
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user