mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
jpegls: use the AVFrame API properly.
This commit is contained in:
parent
14b35bf065
commit
706a92926c
@ -33,7 +33,6 @@
|
|||||||
|
|
||||||
typedef struct JpeglsContext {
|
typedef struct JpeglsContext {
|
||||||
AVCodecContext *avctx;
|
AVCodecContext *avctx;
|
||||||
AVFrame picture;
|
|
||||||
} JpeglsContext;
|
} JpeglsContext;
|
||||||
|
|
||||||
typedef struct JLSState {
|
typedef struct JLSState {
|
||||||
|
@ -248,8 +248,7 @@ static void ls_store_lse(JLSState *state, PutBitContext *pb)
|
|||||||
static int encode_picture_ls(AVCodecContext *avctx, AVPacket *pkt,
|
static int encode_picture_ls(AVCodecContext *avctx, AVPacket *pkt,
|
||||||
const AVFrame *pict, int *got_packet)
|
const AVFrame *pict, int *got_packet)
|
||||||
{
|
{
|
||||||
JpeglsContext *const s = avctx->priv_data;
|
const AVFrame *const p = pict;
|
||||||
AVFrame *const p = &s->picture;
|
|
||||||
const int near = avctx->prediction_method;
|
const int near = avctx->prediction_method;
|
||||||
PutBitContext pb, pb2;
|
PutBitContext pb, pb2;
|
||||||
GetBitContext gb;
|
GetBitContext gb;
|
||||||
@ -258,10 +257,6 @@ static int encode_picture_ls(AVCodecContext *avctx, AVPacket *pkt,
|
|||||||
int i, size, ret;
|
int i, size, ret;
|
||||||
int comps;
|
int comps;
|
||||||
|
|
||||||
*p = *pict;
|
|
||||||
p->pict_type = AV_PICTURE_TYPE_I;
|
|
||||||
p->key_frame = 1;
|
|
||||||
|
|
||||||
if (avctx->pix_fmt == AV_PIX_FMT_GRAY8 ||
|
if (avctx->pix_fmt == AV_PIX_FMT_GRAY8 ||
|
||||||
avctx->pix_fmt == AV_PIX_FMT_GRAY16)
|
avctx->pix_fmt == AV_PIX_FMT_GRAY16)
|
||||||
comps = 1;
|
comps = 1;
|
||||||
@ -346,7 +341,7 @@ static int encode_picture_ls(AVCodecContext *avctx, AVPacket *pkt,
|
|||||||
Rc[j] = last[j];
|
Rc[j] = last[j];
|
||||||
}
|
}
|
||||||
last = cur;
|
last = cur;
|
||||||
cur += s->picture.linesize[0];
|
cur += p->linesize[0];
|
||||||
}
|
}
|
||||||
} else if (avctx->pix_fmt == AV_PIX_FMT_BGR24) {
|
} else if (avctx->pix_fmt == AV_PIX_FMT_BGR24) {
|
||||||
int j, width;
|
int j, width;
|
||||||
@ -360,7 +355,7 @@ static int encode_picture_ls(AVCodecContext *avctx, AVPacket *pkt,
|
|||||||
Rc[j] = last[j];
|
Rc[j] = last[j];
|
||||||
}
|
}
|
||||||
last = cur;
|
last = cur;
|
||||||
cur += s->picture.linesize[0];
|
cur += p->linesize[0];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -400,12 +395,20 @@ static int encode_picture_ls(AVCodecContext *avctx, AVPacket *pkt,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static av_cold int encode_close(AVCodecContext *avctx)
|
||||||
|
{
|
||||||
|
av_frame_free(&avctx->coded_frame);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static av_cold int encode_init_ls(AVCodecContext *ctx)
|
static av_cold int encode_init_ls(AVCodecContext *ctx)
|
||||||
{
|
{
|
||||||
JpeglsContext *c = (JpeglsContext *)ctx->priv_data;
|
ctx->coded_frame = av_frame_alloc();
|
||||||
|
if (!ctx->coded_frame)
|
||||||
|
return AVERROR(ENOMEM);
|
||||||
|
|
||||||
c->avctx = ctx;
|
ctx->coded_frame->pict_type = AV_PICTURE_TYPE_I;
|
||||||
ctx->coded_frame = &c->picture;
|
ctx->coded_frame->key_frame = 1;
|
||||||
|
|
||||||
if (ctx->pix_fmt != AV_PIX_FMT_GRAY8 &&
|
if (ctx->pix_fmt != AV_PIX_FMT_GRAY8 &&
|
||||||
ctx->pix_fmt != AV_PIX_FMT_GRAY16 &&
|
ctx->pix_fmt != AV_PIX_FMT_GRAY16 &&
|
||||||
@ -423,8 +426,8 @@ AVCodec ff_jpegls_encoder = {
|
|||||||
.long_name = NULL_IF_CONFIG_SMALL("JPEG-LS"),
|
.long_name = NULL_IF_CONFIG_SMALL("JPEG-LS"),
|
||||||
.type = AVMEDIA_TYPE_VIDEO,
|
.type = AVMEDIA_TYPE_VIDEO,
|
||||||
.id = AV_CODEC_ID_JPEGLS,
|
.id = AV_CODEC_ID_JPEGLS,
|
||||||
.priv_data_size = sizeof(JpeglsContext),
|
|
||||||
.init = encode_init_ls,
|
.init = encode_init_ls,
|
||||||
|
.close = encode_close,
|
||||||
.encode2 = encode_picture_ls,
|
.encode2 = encode_picture_ls,
|
||||||
.pix_fmts = (const enum AVPixelFormat[]) {
|
.pix_fmts = (const enum AVPixelFormat[]) {
|
||||||
AV_PIX_FMT_BGR24, AV_PIX_FMT_RGB24,
|
AV_PIX_FMT_BGR24, AV_PIX_FMT_RGB24,
|
||||||
|
Loading…
Reference in New Issue
Block a user