1/*
2INTEL CONFIDENTIAL
3Copyright 2009 Intel Corporation All Rights Reserved.
4The source code contained or described herein and all documents related to the source code ("Material") are owned by Intel Corporation or its suppliers or licensors. Title to the Material remains with Intel Corporation or its suppliers and licensors. The Material contains trade secrets and proprietary and confidential information of Intel or its suppliers and licensors. The Material is protected by worldwide copyright and trade secret laws and treaty provisions. No part of the Material may be used, copied, reproduced, modified, published, uploaded, posted, transmitted, distributed, or disclosed in any way without Intel’s prior express written permission.
5
6No license under any patent, copyright, trade secret or other intellectual property right is granted to or conferred upon you by disclosure or delivery of the Materials, either expressly, by implication, inducement, estoppel or otherwise. Any license under such intellectual property rights must be express and approved by Intel in writing.
7*/
8
9#ifndef __MIX_VIDEOCONFIGPARAMSENC_MPEG4_H__
10#define __MIX_VIDEOCONFIGPARAMSENC_MPEG4_H__
11
12#include "mixvideoconfigparamsenc.h"
13#include "mixvideodef.h"
14
15/**
16* MIX_TYPE_VIDEOCONFIGPARAMSENC_MPEG4:
17*
18* Get type of class.
19*/
20#define MIX_TYPE_VIDEOCONFIGPARAMSENC_MPEG4 (mix_videoconfigparamsenc_mpeg4_get_type ())
21
22/**
23* MIX_VIDEOCONFIGPARAMSENC_MPEG4:
24* @obj: object to be type-casted.
25*/
26#define MIX_VIDEOCONFIGPARAMSENC_MPEG4(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), MIX_TYPE_VIDEOCONFIGPARAMSENC_MPEG4, MixVideoConfigParamsEncMPEG4))
27
28/**
29* MIX_IS_VIDEOCONFIGPARAMSENC_MPEG4:
30* @obj: an object.
31*
32* Checks if the given object is an instance of #MixVideoConfigParamsEncMPEG4
33*/
34#define MIX_IS_VIDEOCONFIGPARAMSENC_MPEG4(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), MIX_TYPE_VIDEOCONFIGPARAMSENC_MPEG4))
35
36/**
37* MIX_VIDEOCONFIGPARAMSENC_MPEG4_CLASS:
38* @klass: class to be type-casted.
39*/
40#define MIX_VIDEOCONFIGPARAMSENC_MPEG4_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), MIX_TYPE_VIDEOCONFIGPARAMSENC_MPEG4, MixVideoConfigParamsEncMPEG4Class))
41
42/**
43* MIX_IS_VIDEOCONFIGPARAMSENC_MPEG4_CLASS:
44* @klass: a class.
45*
46* Checks if the given class is #MixVideoConfigParamsEncMPEG4Class
47*/
48#define MIX_IS_VIDEOCONFIGPARAMSENC_MPEG4_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), MIX_TYPE_VIDEOCONFIGPARAMSENC_MPEG4))
49
50/**
51* MIX_VIDEOCONFIGPARAMSENC_MPEG4_GET_CLASS:
52* @obj: a #MixParams object.
53*
54* Get the class instance of the object.
55*/
56#define MIX_VIDEOCONFIGPARAMSENC_MPEG4_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), MIX_TYPE_VIDEOCONFIGPARAMSENC_MPEG4, MixVideoConfigParamsEncMPEG4Class))
57
58typedef struct _MixVideoConfigParamsEncMPEG4 MixVideoConfigParamsEncMPEG4;
59typedef struct _MixVideoConfigParamsEncMPEG4Class MixVideoConfigParamsEncMPEG4Class;
60
61/**
62* MixVideoConfigParamsEncMPEG4:
63*
64* MI-X VideoConfig Parameter object
65*/
66struct _MixVideoConfigParamsEncMPEG4
67{
68  /*< public > */
69  MixVideoConfigParamsEnc parent;
70
71  /*< public > */
72
73  /* TODO: Add MPEG-4 configuration paramters */
74  guchar  profile_and_level_indication;
75  guint fixed_vop_time_increment;
76  guint disable_deblocking_filter_idc;
77
78  void *reserved1;
79  void *reserved2;
80  void *reserved3;
81  void *reserved4;
82};
83
84/**
85* MixVideoConfigParamsEncMPEG4Class:
86*
87* MI-X VideoConfig object class
88*/
89struct _MixVideoConfigParamsEncMPEG4Class
90{
91  /*< public > */
92  MixVideoConfigParamsEncClass parent_class;
93
94  /* class members */
95};
96
97/**
98* mix_videoconfigparamsenc_mpeg4_get_type:
99* @returns: type
100*
101* Get the type of object.
102*/
103GType mix_videoconfigparamsenc_mpeg4_get_type (void);
104
105/**
106* mix_videoconfigparamsenc_mpeg4_new:
107* @returns: A newly allocated instance of #MixVideoConfigParamsEncMPEG4
108*
109* Use this method to create new instance of #MixVideoConfigParamsEncMPEG4
110*/
111MixVideoConfigParamsEncMPEG4 *mix_videoconfigparamsenc_mpeg4_new (void);
112/**
113* mix_videoconfigparamsenc_mpeg4_ref:
114* @mix: object to add reference
115* @returns: the MixVideoConfigParamsEncMPEG4 instance where reference count has been increased.
116*
117* Add reference count.
118*/
119MixVideoConfigParamsEncMPEG4
120  * mix_videoconfigparamsenc_mpeg4_ref (MixVideoConfigParamsEncMPEG4 * mix);
121
122/**
123* mix_videoconfigparamsenc_mpeg4_unref:
124* @obj: object to unref.
125*
126* Decrement reference count of the object.
127*/
128#define mix_videoconfigparamsenc_mpeg4_unref(obj) mix_params_unref(MIX_PARAMS(obj))
129
130/* Class Methods */
131
132/* TODO: Add getters and setters for other properties */
133
134MIX_RESULT mix_videoconfigparamsenc_mpeg4_set_dlk (MixVideoConfigParamsEncMPEG4 * obj,
135		guint disable_deblocking_filter_idc);
136
137MIX_RESULT mix_videoconfigparamsenc_mpeg4_get_dlk (MixVideoConfigParamsEncMPEG4 * obj,
138		guint * disable_deblocking_filter_idc);
139
140MIX_RESULT mix_videoconfigparamsenc_mpeg4_set_profile_level (MixVideoConfigParamsEncMPEG4 * obj,
141		guchar profile_and_level_indication);
142
143MIX_RESULT mix_videoconfigparamsenc_mpeg4_get_profile_level (MixVideoConfigParamsEncMPEG4 * obj,
144		guchar * profile_and_level_indication);
145
146MIX_RESULT mix_videoconfigparamsenc_mpeg4_set_fixed_vti (MixVideoConfigParamsEncMPEG4 * obj,
147		guint fixed_vop_time_increment);
148
149MIX_RESULT mix_videoconfigparamsenc_mpeg4_get_fixed_vti (MixVideoConfigParamsEncMPEG4 * obj,
150		guint * fixed_vop_time_increment);
151
152#endif /* __MIX_VIDEOCONFIGPARAMSENC_MPEG4_H__ */
153