hmhd.c
上传用户:sun1608
上传日期:2007-02-02
资源大小:6116k
文件大小:2k
源码类别:

流媒体/Mpeg4/MP4

开发平台:

Visual C++

  1. /*
  2.  * The contents of this file are subject to the Mozilla Public
  3.  * License Version 1.1 (the "License"); you may not use this file
  4.  * except in compliance with the License. You may obtain a copy of
  5.  * the License at http://www.mozilla.org/MPL/
  6.  * 
  7.  * Software distributed under the License is distributed on an "AS
  8.  * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
  9.  * implied. See the License for the specific language governing
  10.  * rights and limitations under the License.
  11.  * 
  12.  * The Original Code is MPEG4IP.
  13.  * 
  14.  * The Initial Developer of the Original Code is Cisco Systems Inc.
  15.  * Portions created by Cisco Systems Inc. are
  16.  * Copyright (C) Cisco Systems Inc. 2000, 2001.  All Rights Reserved.
  17.  * 
  18.  * Contributor(s): 
  19.  * Dave Mackie dmackie@cisco.com
  20.  */
  21. #include "quicktime.h"
  22. int quicktime_hmhd_init(quicktime_hmhd_t *hmhd)
  23. {
  24. hmhd->version = 0;
  25. hmhd->flags = 0;
  26. hmhd->maxPDUsize = 0;
  27. hmhd->avgPDUsize = 0;
  28. hmhd->maxbitrate = 0;
  29. hmhd->avgbitrate = 0;
  30. hmhd->slidingavgbitrate = 0;
  31. }
  32. int quicktime_hmhd_delete(quicktime_hmhd_t *hmhd)
  33. {
  34. }
  35. int quicktime_hmhd_dump(quicktime_hmhd_t *hmhd)
  36. {
  37. printf("    hint media headern");
  38. printf("     version %dn", hmhd->version);
  39. printf("     flags %dn", hmhd->flags);
  40. printf("     maxPDUsize %dn", hmhd->maxPDUsize);
  41. printf("     avgPDUsize %dn", hmhd->avgPDUsize);
  42. printf("     maxbitrate %dn", hmhd->maxbitrate);
  43. printf("     avgbitrate %dn", hmhd->avgbitrate);
  44. printf("     slidingavgbitrate %dn", hmhd->slidingavgbitrate);
  45. }
  46. int quicktime_read_hmhd(quicktime_t *file, quicktime_hmhd_t *hmhd)
  47. {
  48. int i;
  49. hmhd->version = quicktime_read_char(file);
  50. hmhd->flags = quicktime_read_int24(file);
  51. hmhd->maxPDUsize = quicktime_read_int16(file);
  52. hmhd->avgPDUsize = quicktime_read_int16(file);
  53. hmhd->maxbitrate = quicktime_read_int32(file);
  54. hmhd->avgbitrate = quicktime_read_int32(file);
  55. hmhd->slidingavgbitrate = quicktime_read_int32(file);
  56. }
  57. int quicktime_write_hmhd(quicktime_t *file, quicktime_hmhd_t *hmhd)
  58. {
  59. quicktime_atom_t atom;
  60. int i;
  61. quicktime_atom_write_header(file, &atom, "hmhd");
  62. quicktime_write_char(file, hmhd->version);
  63. quicktime_write_int24(file, hmhd->flags);
  64. quicktime_write_int16(file, hmhd->maxPDUsize);
  65. quicktime_write_int16(file, hmhd->avgPDUsize);
  66. quicktime_write_int32(file, hmhd->maxbitrate);
  67. quicktime_write_int32(file, hmhd->avgbitrate);
  68. quicktime_write_int32(file, hmhd->slidingavgbitrate);
  69. quicktime_atom_write_footer(file, &atom);
  70. }