You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

64 lines
2.2KB

  1. /*
  2. * Copyright (c) 2008 BBC, Anuradha Suraparaju <asuraparaju at gmail dot com >
  3. *
  4. * This file is part of FFmpeg.
  5. *
  6. * FFmpeg is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 2.1 of the License, or (at your option) any later version.
  10. *
  11. * FFmpeg is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public
  17. * License along with FFmpeg; if not, write to the Free Software
  18. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  19. */
  20. /**
  21. * @file libavcodec/libschroedinger.h
  22. * data structures common to libschroedingerdec.c and libschroedingerenc.c
  23. */
  24. #ifndef AVCODEC_LIBSCHROEDINGER_H
  25. #define AVCODEC_LIBSCHROEDINGER_H
  26. #include <schroedinger/schrobitstream.h>
  27. #include <schroedinger/schroframe.h>
  28. #include "avcodec.h"
  29. static const struct {
  30. enum PixelFormat ff_pix_fmt;
  31. SchroChromaFormat schro_pix_fmt;
  32. SchroFrameFormat schro_frame_fmt;
  33. } ffmpeg_schro_pixel_format_map[] = {
  34. { PIX_FMT_YUV420P, SCHRO_CHROMA_420, SCHRO_FRAME_FORMAT_U8_420 },
  35. { PIX_FMT_YUV422P, SCHRO_CHROMA_422, SCHRO_FRAME_FORMAT_U8_422 },
  36. { PIX_FMT_YUV444P, SCHRO_CHROMA_444, SCHRO_FRAME_FORMAT_U8_444 },
  37. };
  38. /**
  39. * Returns the video format preset matching the input video dimensions and
  40. * time base.
  41. */
  42. SchroVideoFormatEnum ff_get_schro_video_format_preset (AVCodecContext *avccontext);
  43. /**
  44. * Sets the Schroedinger frame format corresponding to the Schro chroma format
  45. * passed. Returns 0 on success, -1 on failure.
  46. */
  47. int ff_get_schro_frame_format(SchroChromaFormat schro_chroma_fmt,
  48. SchroFrameFormat *schro_frame_fmt);
  49. /**
  50. * Create a Schro frame based on the dimensions and frame format
  51. * passed. Returns a pointer to a frame on success, NULL on failure.
  52. */
  53. SchroFrame *ff_create_schro_frame(AVCodecContext *avccontext,
  54. SchroFrameFormat schro_frame_fmt);
  55. #endif /* AVCODEC_LIBSCHROEDINGER_H */