# HG changeset patch # User rtognimp # Date 1107210842 0 # Node ID 0803adcb3ec38e3cfd28549ec16f40a8b3f7b5aa # Parent 5252700f61df438e6c52ed6eab08971d6b7bd02e Add 32bit RGB support diff -r 5252700f61df -r 0803adcb3ec3 tscc.c --- a/tscc.c Mon Jan 31 21:26:20 2005 +0000 +++ b/tscc.c Mon Jan 31 22:34:02 2005 +0000 @@ -116,7 +116,7 @@ } pos += p2; } else { //Run of pixels - int pix[3]; //original pixel + int pix[4]; //original pixel switch(c->bpp){ case 8: pix[0] = *src++; break; @@ -127,6 +127,11 @@ pix[1] = *src++; pix[2] = *src++; break; + case 32: pix[0] = *src++; + pix[1] = *src++; + pix[2] = *src++; + pix[3] = *src++; + break; } if (output + p1 * (c->bpp / 8) > output_end) continue; @@ -141,6 +146,11 @@ *output++ = pix[1]; *output++ = pix[2]; break; + case 32: *output++ = pix[0]; + *output++ = pix[1]; + *output++ = pix[2]; + *output++ = pix[3]; + break; } } pos += p1; @@ -252,9 +262,10 @@ switch(avctx->bits_per_sample){ case 8: avctx->pix_fmt = PIX_FMT_PAL8; break; case 16: avctx->pix_fmt = PIX_FMT_RGB555; break; - case 24: av_log(avctx, AV_LOG_ERROR, "Camtasia warning: RGB24 is just guessed\n"); + case 24: avctx->pix_fmt = PIX_FMT_BGR24; break; + case 32: avctx->pix_fmt = PIX_FMT_RGBA32; break; default: av_log(avctx, AV_LOG_ERROR, "Camtasia error: unknown depth %i bpp\n", avctx->bits_per_sample); return -1; }