VideoEditorMain.cpp revision beb9fc8ee8d3bd14d141104e91d41809dcfe0e1a
1cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi/*
2cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi * Copyright (C) 2011 The Android Open Source Project
3cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi *
4cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi * Licensed under the Apache License, Version 2.0 (the "License");
5cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi * you may not use this file except in compliance with the License.
6cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi * You may obtain a copy of the License at
7cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi *
8cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi *      http://www.apache.org/licenses/LICENSE-2.0
9cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi *
10cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi * Unless required by applicable law or agreed to in writing, software
11cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi * distributed under the License is distributed on an "AS IS" BASIS,
12cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi * See the License for the specific language governing permissions and
14cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi * limitations under the License.
15cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi */
16cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
17cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <dlfcn.h>
18cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <stdio.h>
19cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <unistd.h>
20cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <utils/Log.h>
21cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <utils/threads.h>
22cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <VideoEditorClasses.h>
23cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <VideoEditorJava.h>
24cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <VideoEditorOsal.h>
25cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <VideoEditorLogging.h>
26cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <marker.h>
27cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <VideoEditorClasses.h>
28cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <VideoEditorThumbnailMain.h>
29cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4OSA_Debug.h>
30cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4xVSS_Internal.h>
31cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <surfaceflinger/Surface.h>
32cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <surfaceflinger/ISurface.h>
33cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include "VideoEditorPreviewController.h"
34cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
35cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include "VideoEditorMain.h"
36cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
37cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargiextern "C" {
38cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4OSA_Clock.h>
39cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4OSA_CharStar.h>
40cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4OSA_Error.h>
41cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4OSA_FileCommon.h>
42cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4OSA_FileReader.h>
43cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4OSA_FileWriter.h>
44cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4OSA_FileExtra.h>
45cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4OSA_Memory.h>
46cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4OSA_String.h>
47cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4OSA_Thread.h>
48cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4xVSS_API.h>
49cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4VSS3GPP_ErrorCodes.h>
50cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4MCS_API.h>
51cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4MCS_ErrorCodes.h>
52cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4MDP_API.h>
53cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4READER_Common.h>
54cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#include <M4WRITER_common.h>
55cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi};
56cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
57cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
58cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargiusing namespace android;
59cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
60cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#define THREAD_STACK_SIZE       (65536)
61cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
62cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#define VIDEOEDITOR_VERSION_MAJOR     0
63cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#define VIDEOEDITOR_VERSION_MINOR     0
64cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#define VIDEOEDITOR_VERSION_REVISION  1
65cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
66cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
67cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargitypedef enum
68cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
69cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditState_NOT_INITIALIZED,
70cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditState_INITIALIZED,
71cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditState_ANALYZING,
72cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditState_ANALYZING_ERROR,
73cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditState_OPENED,
74cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditState_SAVING,
75cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditState_SAVING_ERROR,
76cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditState_SAVED,
77cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditState_STOPPING
78cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi} ManualEditState;
79cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
80cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargitypedef struct
81cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
82cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    JavaVM*                        pVM;
83cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jobject                        engine;
84cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jmethodID                      onCompletionMethodId;
85cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jmethodID                      onErrorMethodId;
86cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jmethodID                      onWarningMethodId;
87cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jmethodID                      onProgressUpdateMethodId;
88cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jmethodID                      onPreviewProgressUpdateMethodId;
89c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    jmethodID                      previewFrameEditInfoId;
90cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4xVSS_InitParams              initParams;
91cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    void*                          pTextRendererHandle;
92cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4xVSS_getTextRgbBufferFct     pTextRendererFunction;
93cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Context                  engineContext;
94cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditState                state;
95cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4VSS3GPP_EditSettings*        pEditSettings;
96cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Context                  threadContext;
97cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR                      threadResult;
98cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt8                    threadProgress;
99cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VideoEditorPreviewController   *mPreviewController;
100cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4xVSS_AudioMixingSettings     *mAudioSettings;
101cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* Audio Graph changes */
102cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Context                   pAudioGraphMCSCtx;
103cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Bool                      bSkipState;
104cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jmethodID                       onAudioGraphProgressUpdateMethodId;
105cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    Mutex                           mLock;
106c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    bool                            mIsUpdateOverlay;
107c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    char                            *mOverlayFileName;
108c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    int                             mOverlayRenderingMode;
109cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi} ManualEditContext;
110cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
111cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargiextern "C" M4OSA_ERR M4MCS_open_normalMode(
112cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4MCS_Context                       pContext,
113cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_Void*                         pFileIn,
114cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4VIDEOEDITING_FileType             InputFileType,
115cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_Void*                         pFileOut,
116cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_Void*                         pTempFile);
117cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
118cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic M4OSA_ERR videoEditor_toUTF8Fct(
119cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_Void*                         pBufferIn,
120cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_UInt8*                        pBufferOut,
121cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_UInt32*                       bufferOutSize);
122cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
123cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic M4OSA_ERR videoEditor_fromUTF8Fct(
124cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_UInt8*                        pBufferIn,
125cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_Void*                         pBufferOut,
126cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_UInt32*                       bufferOutSize);
127cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
128cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic M4OSA_ERR videoEditor_getTextRgbBufferFct(
129cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_Void*                         pRenderingData,
130cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_Void*                         pTextBuffer,
131cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_UInt32                        textBufferSize,
132cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4VIFI_ImagePlane**                 pOutputPlane);
133cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
134cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void videoEditor_callOnProgressUpdate(
135cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                ManualEditContext*                  pContext,
136cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                int                                 task,
137cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                int                                 progress);
138cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
139cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void videoEditor_freeContext(
140cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
141cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                ManualEditContext**                 ppContext);
142cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
143cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic M4OSA_ERR videoEditor_threadProc(
144cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_Void*                         param);
145cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
146cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic jobject videoEditor_getVersion(
147cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
148cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             thiz);
149cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
150cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void videoEditor_init(
151cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
152cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             thiz,
153cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jstring                             tempPath,
154cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jstring                             textRendererPath);
155cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
156cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void videoEditor_loadSettings(
157cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
158cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             thiz,
159cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             settings);
160cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
161cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void videoEditor_unloadSettings(
162cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
163cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             thiz);
164cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
165cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
166cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void videoEditor_stopEncoding(
167cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
168cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             thiz);
169cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
170cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void videoEditor_release(
171cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
172cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             thiz);
173cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic int videoEditor_getPixels(
174cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 JNIEnv*                  env,
175cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 jobject                  thiz,
176cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 jstring                  path,
177cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 jintArray                pixelArray,
178cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 M4OSA_UInt32             width,
179cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 M4OSA_UInt32             height,
180cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 M4OSA_UInt32             timeMS);
181cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic int videoEditor_getPixelsList(
182cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     JNIEnv*                  env,
183cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     jobject                  thiz,
184cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     jstring                  path,
185cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     jintArray                pixelArray,
186cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     M4OSA_UInt32             width,
187cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     M4OSA_UInt32             height,
188cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     M4OSA_UInt32             deltatimeMS,
189cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     M4OSA_UInt32             noOfThumbnails,
190cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     M4OSA_UInt32             startTime,
191cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     M4OSA_UInt32             endTime);
192cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
193cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void
194cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_startPreview(
195cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                 pEnv,
196cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                 thiz,
197cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                 mSurface,
198cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jlong                   fromMs,
199cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jlong                   toMs,
200cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jint                    callbackInterval,
201cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jboolean                loop);
202cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
203cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void
204cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_populateSettings(
205cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                 pEnv,
206cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                 thiz,
207cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                 settings,
208cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                 object,
209cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                 audioSettingObject);
210cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
211cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void videoEditor_stopPreview(JNIEnv*  pEnv,
212cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                              jobject  thiz);
213cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
214cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic jobject
215cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_getProperties(
216cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
217cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             thiz,
218cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jstring                             file);
219cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
220cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic int videoEditor_renderPreviewFrame(JNIEnv* pEnv,
221cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    jobject thiz,
222cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    jobject    mSurface,
223cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    jlong fromMs,
224cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    jint  surfaceWidth,
225cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    jint  surfaceHeight);
226cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
227cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic int videoEditor_registerManualEditMethods(
228cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv);
229cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
230cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void jniPreviewProgressCallback(void* cookie, M4OSA_UInt32 msgType,
231c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                                        void *argc);
232cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
23305d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharmastatic int videoEditor_renderMediaItemPreviewFrame(JNIEnv* pEnv,
234cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                    jobject thiz,
235cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                    jobject mSurface,
236cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                    jstring filePath,
237cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                    jint frameWidth,
238cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                    jint frameHeight,
239cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                    jint surfaceWidth,
240cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                    jint surfaceHeight,
241cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                    jlong fromMs);
242cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
243cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic int videoEditor_generateAudioWaveFormSync ( JNIEnv*     pEnv,
244cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                  jobject     thiz,
245cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                  jstring     pcmfilePath,
246cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                  jstring     outGraphfilePath,
247cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                  jint        frameDuration,
248cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                  jint        channels,
249cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                  jint        samplesCount);
250cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
251cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic int videoEditor_generateAudioRawFile(JNIEnv* pEnv,
252cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    jobject thiz,
253cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    jstring infilePath,
254cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    jstring pcmfilePath );
255cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
256cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargiM4OSA_ERR videoEditor_generateAudio(JNIEnv* pEnv,ManualEditContext* pContext,
257cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    M4OSA_Char* infilePath,
258cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    M4OSA_Char* pcmfilePath );
259cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
260cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic int
261cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_generateClip(
262cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
263cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             thiz,
264cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             settings);
265cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
26605d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharmastatic void videoEditor_clearSurface(JNIEnv* pEnv,
26705d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma                                    jobject thiz,
2681ac760afabeb19ced48a788c7b675baba47d4db3Dheeraj Sharma                                    jobject surface);
269cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
270cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic JNINativeMethod gManualEditMethods[] = {
271cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {"getVersion",               "()L"VERSION_CLASS_NAME";",
272cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                (void *)videoEditor_getVersion      },
273cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {"_init",                    "(Ljava/lang/String;Ljava/lang/String;)V",
274cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                (void *)videoEditor_init    },
275cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {"nativeStartPreview",       "(Landroid/view/Surface;JJIZ)V",
276cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                (void *)videoEditor_startPreview    },
277cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {"nativePopulateSettings",
278cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            "(L"EDIT_SETTINGS_CLASS_NAME";L"PREVIEW_PROPERTIES_CLASS_NAME";L"
279cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            AUDIO_SETTINGS_CLASS_NAME";)V",
280cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                (void *)videoEditor_populateSettings    },
281cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {"nativeRenderPreviewFrame", "(Landroid/view/Surface;JII)I",
282cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                (int *)videoEditor_renderPreviewFrame     },
283cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {"nativeRenderMediaItemPreviewFrame",
284cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    "(Landroid/view/Surface;Ljava/lang/String;IIIIJ)I",
285cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                        (int *)videoEditor_renderMediaItemPreviewFrame     },
286cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {"nativeStopPreview",       "()V",
287cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                (void *)videoEditor_stopPreview            },
288cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {"stopEncoding",            "()V",
289cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                (void *)videoEditor_stopEncoding         },
290cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {"release",                 "()V",
291cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                (void *)videoEditor_release            },
292cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {"nativeGetPixels",         "(Ljava/lang/String;[IIIJ)I",
293cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                (void*)videoEditor_getPixels               },
294cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {"nativeGetPixelsList",     "(Ljava/lang/String;[IIIIIJJ)I",
295cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                (void*)videoEditor_getPixelsList           },
296cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {"getMediaProperties",
297cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    "(Ljava/lang/String;)Landroid/media/videoeditor/MediaArtistNativeHelper$Properties;",
298cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                (void *)videoEditor_getProperties          },
299cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {"nativeGenerateAudioGraph","(Ljava/lang/String;Ljava/lang/String;III)I",
300cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                (int *)videoEditor_generateAudioWaveFormSync },
301cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {"nativeGenerateRawAudio",  "(Ljava/lang/String;Ljava/lang/String;)I",
302cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                (int *)videoEditor_generateAudioRawFile      },
303cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {"nativeGenerateClip",      "(L"EDIT_SETTINGS_CLASS_NAME";)I",
304cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                (void *)videoEditor_generateClip  },
3051ac760afabeb19ced48a788c7b675baba47d4db3Dheeraj Sharma    {"nativeClearSurface",       "(Landroid/view/Surface;)V",
30605d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma                                (void *)videoEditor_clearSurface  },
307cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi};
308cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
309cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi// temp file name of VSS out file
3105618e037af1a9d4323990a580d4181b9bc8e3091Dheeraj Sharma#define TEMP_MCS_OUT_FILE_PATH "tmpOut.3gp"
311cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
312cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargivoid
313cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargigetClipSetting(
314cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                                       pEnv,
315cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                                       object,
316cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4VSS3GPP_ClipSettings*                       pSettings)
317cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
318cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
319cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jfieldID fid;
320cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    int field = 0;
321cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool needToBeLoaded = true;
322cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jclass clazz = pEnv->FindClass(PROPERTIES_CLASS_NAME);
323cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
324cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
325cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == clazz),
326cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
327cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
328cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    fid = pEnv->GetFieldID(clazz,"duration","I");
329cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pSettings->ClipProperties.uiClipDuration = pEnv->GetIntField(object,fid);
330cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_TRACE1_1("duration = %d",pSettings->ClipProperties.uiClipDuration);
331cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
332cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    fid = pEnv->GetFieldID(clazz,"videoFormat","I");
333cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pSettings->ClipProperties.VideoStreamType =
334cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4VIDEOEDITING_VideoFormat)pEnv->GetIntField(object,fid);
335cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_TRACE1_1("videoFormat = %d",pSettings->ClipProperties.VideoStreamType);
336cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
337cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    fid = pEnv->GetFieldID(clazz,"videoDuration","I");
338cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pSettings->ClipProperties.uiClipVideoDuration = pEnv->GetIntField(object,fid);
339cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_TRACE1_1("videoDuration = %d",
340cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    pSettings->ClipProperties.uiClipVideoDuration);
341cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
342cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    fid = pEnv->GetFieldID(clazz,"width","I");
343cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pSettings->ClipProperties.uiVideoWidth = pEnv->GetIntField(object,fid);
344cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_TRACE1_1("width = %d",pSettings->ClipProperties.uiVideoWidth);
345cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
346cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    fid = pEnv->GetFieldID(clazz,"height","I");
347cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pSettings->ClipProperties.uiVideoHeight = pEnv->GetIntField(object,fid);
348cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_TRACE1_1("height = %d",pSettings->ClipProperties.uiVideoHeight);
349cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
350cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    fid = pEnv->GetFieldID(clazz,"audioFormat","I");
351cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pSettings->ClipProperties.AudioStreamType =
352cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4VIDEOEDITING_AudioFormat)pEnv->GetIntField(object,fid);
353cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_TRACE1_1("audioFormat = %d",pSettings->ClipProperties.AudioStreamType);
354cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
355cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    fid = pEnv->GetFieldID(clazz,"audioDuration","I");
356cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pSettings->ClipProperties.uiClipAudioDuration = pEnv->GetIntField(object,fid);
357cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_TRACE1_1("audioDuration = %d",
358cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    pSettings->ClipProperties.uiClipAudioDuration);
359cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
360cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    fid = pEnv->GetFieldID(clazz,"audioBitrate","I");
361cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pSettings->ClipProperties.uiAudioBitrate = pEnv->GetIntField(object,fid);
362cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_TRACE1_1("audioBitrate = %d",pSettings->ClipProperties.uiAudioBitrate);
363cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
364cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    fid = pEnv->GetFieldID(clazz,"audioChannels","I");
365cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pSettings->ClipProperties.uiNbChannels = pEnv->GetIntField(object,fid);
366cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_TRACE1_1("audioChannels = %d",pSettings->ClipProperties.uiNbChannels);
367cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
368cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    fid = pEnv->GetFieldID(clazz,"audioSamplingFrequency","I");
369cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pSettings->ClipProperties.uiSamplingFrequency = pEnv->GetIntField(object,fid);
370cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_TRACE1_1("audioSamplingFrequency = %d",
371cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    pSettings->ClipProperties.uiSamplingFrequency);
372cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
373cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi   fid = pEnv->GetFieldID(clazz,"audioVolumeValue","I");
374cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi   pSettings->ClipProperties.uiClipAudioVolumePercentage =
375cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    pEnv->GetIntField(object,fid);
376cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi   M4OSA_TRACE1_1("audioVolumeValue = %d",
377cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    pSettings->ClipProperties.uiClipAudioVolumePercentage);
378cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
379cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
380cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void jniPreviewProgressCallback (void* cookie, M4OSA_UInt32 msgType,
381c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                                        void *argc)
382cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
383cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditContext *pContext = (ManualEditContext *)cookie;
384cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    JNIEnv*     pEnv = NULL;
385cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool        isFinished = false;
386cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    int         currentMs = 0;
387cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    int         error = M4NO_ERROR;
388c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    bool        isUpdateOverlay = false;
389c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    int         overlayEffectIndex;
390c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    char        *extPos;
391c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    bool        isSendProgress = true;
392c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    jstring     tmpFileName;
393c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    VideoEditorCurretEditInfo *pCurrEditInfo;
394cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
395cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Attach the current thread.
396cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext->pVM->AttachCurrentThread(&pEnv, NULL);
397cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    switch(msgType)
398cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
399cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        case MSG_TYPE_PROGRESS_INDICATION:
400c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            currentMs = *(int*)argc;
401cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            break;
402cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        case MSG_TYPE_PLAYER_ERROR:
403cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            currentMs = -1;
404c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            error = *(int*)argc;
405cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            break;
406cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        case MSG_TYPE_PREVIEW_END:
407cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            isFinished = true;
408cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            break;
409c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        case MSG_TYPE_OVERLAY_UPDATE:
410c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        {
411c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            int overlayFileNameLen = 0;
412c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            isSendProgress = false;
413c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            pContext->mIsUpdateOverlay = true;
414c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            pCurrEditInfo = (VideoEditorCurretEditInfo*)argc;
415c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            overlayEffectIndex = pCurrEditInfo->overlaySettingsIndex;
416c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            LOGV("MSG_TYPE_OVERLAY_UPDATE");
417c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
418c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            if (pContext->mOverlayFileName != NULL) {
419c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                M4OSA_free((M4OSA_MemAddr32)pContext->mOverlayFileName);
420c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                pContext->mOverlayFileName = NULL;
421c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            }
422c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
423c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            overlayFileNameLen =
424c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                strlen((const char*)pContext->pEditSettings->Effects[overlayEffectIndex].xVSS.pFramingFilePath);
425c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
426c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            pContext->mOverlayFileName =
427c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                (char*)M4OSA_malloc(overlayFileNameLen+1,
428c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                                    M4VS, (M4OSA_Char*)"videoEdito JNI overlayFile");
429c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            if (pContext->mOverlayFileName != NULL) {
430c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                strncpy (pContext->mOverlayFileName,
431c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                    (const char*)pContext->pEditSettings->\
432c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                    Effects[overlayEffectIndex].xVSS.pFramingFilePath, overlayFileNameLen);
433c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                //Change the name to png file
434c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                extPos = strstr(pContext->mOverlayFileName, ".rgb");
435c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                if (extPos != NULL) {
436c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                    *extPos = '\0';
437c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                } else {
438c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                    LOGE("ERROR the overlay file is incorrect");
439c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                }
440c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
441c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                strcat(pContext->mOverlayFileName, ".png");
442c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                LOGV("Conv string is %s", pContext->mOverlayFileName);
443c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                LOGV("Current Clip index = %d", pCurrEditInfo->clipIndex);
444c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
445c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                pContext->mOverlayRenderingMode = pContext->pEditSettings->\
446c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                         pClipList[pCurrEditInfo->clipIndex]->xVSS.MediaRendering;
447c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                LOGI("rendering mode %d ", pContext->mOverlayRenderingMode);
448c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
449c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            }
450c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
451c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            break;
452c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        }
453c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
454c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        case MSG_TYPE_OVERLAY_CLEAR:
455c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            isSendProgress = false;
456c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            pContext->mOverlayFileName = NULL;
457beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            LOGV("MSG_TYPE_OVERLAY_CLEAR");
458c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            //argc is not used
459c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            pContext->mIsUpdateOverlay = true;
460c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            break;
461cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        default:
462cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            break;
463cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
464cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
465c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    if (isSendProgress) {
466c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        tmpFileName  = pEnv->NewStringUTF(pContext->mOverlayFileName);
467c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        pEnv->CallVoidMethod(pContext->engine,
468c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                pContext->onPreviewProgressUpdateMethodId,
469c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                currentMs,isFinished, pContext->mIsUpdateOverlay,
470c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                tmpFileName, pContext->mOverlayRenderingMode);
471c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
472c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        if (pContext->mIsUpdateOverlay) {
473c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            pContext->mIsUpdateOverlay = false;
474c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        }
475c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
476c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        if (tmpFileName) {
477c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            pEnv->DeleteLocalRef(tmpFileName);
478c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        }
479c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    }
480cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
481cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Detach the current thread.
482cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext->pVM->DetachCurrentThread();
483cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
484cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
485cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void videoEditor_stopPreview(JNIEnv*  pEnv,
486cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                              jobject  thiz)
487cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
488cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditContext* pContext = M4OSA_NULL;
489cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool needToBeLoaded = true;
490cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Get the context.
491cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext =
492cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            (ManualEditContext*)videoEditClasses_getContext(&needToBeLoaded, pEnv, thiz);
493cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
494cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Make sure that the context was set.
495cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
496cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == pContext),
497cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
498cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext->mPreviewController->stopPreview();
499c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
500c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    if (pContext->mOverlayFileName != NULL) {
501c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        M4OSA_free((M4OSA_MemAddr32)pContext->mOverlayFileName);
502c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        pContext->mOverlayFileName = NULL;
503c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    }
504cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
505cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
50605d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharmastatic void videoEditor_clearSurface(JNIEnv* pEnv,
50705d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma                                    jobject thiz,
5081ac760afabeb19ced48a788c7b675baba47d4db3Dheeraj Sharma                                    jobject surface)
50905d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma{
51005d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    bool needToBeLoaded = true;
51105d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    M4OSA_ERR result = M4NO_ERROR;
51205d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    VideoEditor_renderPreviewFrameStr frameStr;
51305d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    const char* pMessage = NULL;
5141ac760afabeb19ced48a788c7b675baba47d4db3Dheeraj Sharma    // Let the size be QVGA
5151ac760afabeb19ced48a788c7b675baba47d4db3Dheeraj Sharma    int width = 320;
5161ac760afabeb19ced48a788c7b675baba47d4db3Dheeraj Sharma    int height = 240;
51705d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    ManualEditContext* pContext = M4OSA_NULL;
51805d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma
51905d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    // Get the context.
52005d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    pContext = (ManualEditContext*)videoEditClasses_getContext(&needToBeLoaded, pEnv, thiz);
52105d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO,
52205d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma                                "VIDEO_EDITOR","pContext = 0x%x",pContext);
52305d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma
52405d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    // Make sure that the context was set.
52505d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
52605d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma                                             (M4OSA_NULL == pContext),
52705d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma                                             "not initialized");
52805d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma
52905d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    // Make sure that the context was set.
53005d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
53105d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma                                 (M4OSA_NULL == pContext->mPreviewController),
53205d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma                                 "not initialized");
53305d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma
53405d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    // Validate the surface parameter.
53505d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    videoEditJava_checkAndThrowIllegalArgumentException(&needToBeLoaded, pEnv,
53605d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma                                                (NULL == surface),
53705d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma                                                "surface is null");
53805d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma
53905d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    jclass surfaceClass = pEnv->FindClass("android/view/Surface");
54005d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
54105d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma                                             (M4OSA_NULL == surfaceClass),
54205d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma                                             "not initialized");
54305d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma
54405d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    jfieldID surface_native =
54505d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma            pEnv->GetFieldID(surfaceClass, ANDROID_VIEW_SURFACE_JNI_ID, "I");
54605d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
54705d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma                                             (M4OSA_NULL == surface_native),
54805d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma                                             "not initialized");
54905d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma
55005d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    Surface* const p = (Surface*)pEnv->GetIntField(surface, surface_native);
55105d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    sp<Surface> previewSurface = sp<Surface>(p);
55205d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma
5531ac760afabeb19ced48a788c7b675baba47d4db3Dheeraj Sharma    frameStr.pBuffer = M4OSA_NULL;
55405d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    frameStr.timeMs = 0;
55505d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    frameStr.uiSurfaceWidth = width;
55605d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    frameStr.uiSurfaceHeight = height;
55705d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    frameStr.uiFrameWidth = width;
55805d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    frameStr.uiFrameHeight = height;
55905d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    frameStr.bApplyEffect = M4OSA_FALSE;
56005d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    frameStr.clipBeginCutTime = 0;
56105d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    frameStr.clipEndCutTime = 0;
56205d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma
5631ac760afabeb19ced48a788c7b675baba47d4db3Dheeraj Sharma    result = pContext->mPreviewController->clearSurface(previewSurface,
56405d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma                                                              &frameStr);
56505d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma    videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv,
56605d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma            (M4NO_ERROR != result), result);
56705d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma
56805d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma  }
56905d9f81bd638a749669192b50e680b166529d5f3Dheeraj Sharma
570cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic int videoEditor_renderPreviewFrame(JNIEnv* pEnv,
571cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    jobject thiz,
572cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    jobject    mSurface,
573cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    jlong fromMs,
574cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    jint surfaceWidth,
575cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    jint surfaceHeight )
576cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
577cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool needToBeLoaded = true;
578cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR result = M4NO_ERROR;
579cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32 timeMs = (M4OSA_UInt32)fromMs;
580cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32 i=0,tnTimeMs = 0, framesizeYuv =0;
581cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4VIFI_UInt8 *pixelArray = M4OSA_NULL;
582cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32    iCurrentClipIndex = 0, uiNumberOfClipsInStoryBoard =0,
583cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    uiClipDuration = 0, uiTotalClipDuration = 0,
584cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    iIncrementedDuration = 0;
585cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VideoEditor_renderPreviewFrameStr frameStr;
586cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Context tnContext = M4OSA_NULL;
587cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    const char* pMessage = NULL;
588581cad2221cb367e9e3ef6991c565cd37ced994fJames Dong    M4VIFI_ImagePlane *yuvPlane = NULL;
589c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    VideoEditorCurretEditInfo  currEditInfo;
590cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
591cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO,
592cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        "VIDEO_EDITOR", "surfaceWidth = %d",surfaceWidth);
593cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO,
594cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        "VIDEO_EDITOR", "surfaceHeight = %d",surfaceHeight);
595cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditContext* pContext = M4OSA_NULL;
596cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Get the context.
597cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext =
598cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            (ManualEditContext*)videoEditClasses_getContext(&needToBeLoaded, pEnv, thiz);
599cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO,
600cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                "VIDEO_EDITOR","pContext = 0x%x",pContext);
601cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
602cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Make sure that the context was set.
603cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
604cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == pContext),
605cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
606cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
607cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Make sure that the context was set.
608cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
609cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 (M4OSA_NULL == pContext->mPreviewController),
610cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 "not initialized");
611cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
612cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Validate the mSurface parameter.
613cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalArgumentException(&needToBeLoaded, pEnv,
614cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                (NULL == mSurface),
615cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                "mSurface is null");
616cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jclass surfaceClass = pEnv->FindClass("android/view/Surface");
617cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
618cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == surfaceClass),
619cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
620cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
621cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jfieldID surface_native =
622cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pEnv->GetFieldID(surfaceClass, ANDROID_VIEW_SURFACE_JNI_ID, "I");
623cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
624cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == surface_native),
625cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
626cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
627cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    Surface* const p = (Surface*)pEnv->GetIntField(mSurface, surface_native);
628cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    sp<Surface> previewSurface = sp<Surface>(p);
629cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
630cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* Determine the total number of clips, total duration*/
631cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    uiNumberOfClipsInStoryBoard = pContext->pEditSettings->uiClipNumber;
632cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
633cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    for (i = 0; i < uiNumberOfClipsInStoryBoard; i++) {
634cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        uiClipDuration = pContext->pEditSettings->pClipList[i]->uiEndCutTime -
635cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->pEditSettings->pClipList[i]->uiBeginCutTime;
636cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        uiTotalClipDuration += uiClipDuration;
637cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
638cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
639cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* determine the clip whose thumbnail needs to be rendered*/
640cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (timeMs == 0) {
641cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        iCurrentClipIndex = 0;
642cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        i=0;
643cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    } else {
644cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR",
645cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            "videoEditor_renderPreviewFrame() timeMs=%d", timeMs);
646cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
647cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (timeMs > uiTotalClipDuration) {
648cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR",
649cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                "videoEditor_renderPreviewFrame() timeMs > uiTotalClipDuration");
650cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pMessage = videoEditJava_getErrorName(M4ERR_PARAMETER);
651cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            jniThrowException(pEnv, "java/lang/IllegalArgumentException", pMessage);
652cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            return -1;
653cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
654cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
655cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        for (i = 0; i < uiNumberOfClipsInStoryBoard; i++) {
656cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            if (timeMs < (iIncrementedDuration +
657cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                          (pContext->pEditSettings->pClipList[i]->uiEndCutTime -
658cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                           pContext->pEditSettings->pClipList[i]->uiBeginCutTime)))
659cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            {
660cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                iCurrentClipIndex = i;
661cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR",
662cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    "videoEditor_renderPreviewFrame() iCurrentClipIndex=%d for timeMs=%d",
663cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    iCurrentClipIndex, timeMs);
664cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                break;
665cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            }
666cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            else {
667cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                iIncrementedDuration = iIncrementedDuration +
668cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    (pContext->pEditSettings->pClipList[i]->uiEndCutTime -
669cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    pContext->pEditSettings->pClipList[i]->uiBeginCutTime);
670cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            }
671cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
672cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
673cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* If timestamp is beyond story board duration, return*/
674cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (i >= uiNumberOfClipsInStoryBoard) {
675cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (timeMs == iIncrementedDuration) {
676cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            iCurrentClipIndex = i-1;
677cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        } else {
678cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi           return -1;
679cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
680cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
681cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
682cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /*+ Handle the image files here */
683cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi      if (pContext->pEditSettings->pClipList[iCurrentClipIndex]->FileType ==
684cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi          /*M4VIDEOEDITING_kFileType_JPG*/ M4VIDEOEDITING_kFileType_ARGB8888 ) {
685cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi          VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", " iCurrentClipIndex %d ", iCurrentClipIndex);
686cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi          VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR",
687cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                "  Height = %d",
688cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                pContext->pEditSettings->pClipList[iCurrentClipIndex]->ClipProperties.uiVideoHeight);
689cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
690cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi          VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR",
691cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                "  Width = %d",
692cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                pContext->pEditSettings->pClipList[iCurrentClipIndex]->ClipProperties.uiVideoWidth);
693cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
694cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi          LvGetImageThumbNail((const char *)pContext->pEditSettings->\
695cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi          pClipList[iCurrentClipIndex]->pFile,
696cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->pEditSettings->pClipList[iCurrentClipIndex]->ClipProperties.uiVideoHeight,
697cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->pEditSettings->pClipList[iCurrentClipIndex]->ClipProperties.uiVideoWidth,
698cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            (M4OSA_Void **)&frameStr.pBuffer);
699cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    } else {
700cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        /* Handle 3gp/mp4 Clips here */
701cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        /* get thumbnail*/
702cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        result = ThumbnailOpen(&tnContext,
703cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            (const M4OSA_Char*)pContext->pEditSettings->\
704cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pClipList[iCurrentClipIndex]->pFile, M4OSA_TRUE);
705cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (result != M4NO_ERROR || tnContext  == M4OSA_NULL) {
706cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            return -1;
707cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
708cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
709cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        /* timeMs is relative to storyboard; in this api it shud be relative to this clip */
710cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if ((i >= uiNumberOfClipsInStoryBoard) &&
711cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            (timeMs == iIncrementedDuration)) {
712cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            tnTimeMs = pContext->pEditSettings->\
713cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pClipList[iCurrentClipIndex]->uiEndCutTime;
714cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        } else {
715cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            tnTimeMs = pContext->pEditSettings->\
716cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pClipList[iCurrentClipIndex]->uiBeginCutTime
717cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            + (timeMs - iIncrementedDuration);
718cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
719cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
720cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR",
721cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            "video width = %d",pContext->pEditSettings->pClipList[iCurrentClipIndex]->\
722cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            ClipProperties.uiVideoWidth);
723cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR",
724cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            "video height = %d",pContext->pEditSettings->pClipList[iCurrentClipIndex]->\
725cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            ClipProperties.uiVideoHeight);
726cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR",
727cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            "current clip index = %d",iCurrentClipIndex);
728cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
729cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_UInt32 width = pContext->pEditSettings->pClipList[iCurrentClipIndex]->\
730cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            ClipProperties.uiVideoWidth;
731cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_UInt32 height = pContext->pEditSettings->pClipList[iCurrentClipIndex]->\
732cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            ClipProperties.uiVideoHeight;
733cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
734cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        framesizeYuv = width * height * 1.5;
735cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
736cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pixelArray = (M4VIFI_UInt8 *)M4OSA_malloc(framesizeYuv, M4VS,
737cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            (M4OSA_Char*)"videoEditor pixelArray");
738cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (pixelArray == M4OSA_NULL) {
739cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR",
740cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                "videoEditor_renderPreviewFrame() malloc error");
741cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            ThumbnailClose(tnContext);
742cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pMessage = videoEditJava_getErrorName(M4ERR_ALLOC);
743cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            jniThrowException(pEnv, "java/lang/RuntimeException", pMessage);
744cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            return -1;
745cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
746cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
747cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        result = ThumbnailGetPixels16(tnContext, (M4OSA_Int16 *)pixelArray,
748cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->pEditSettings->pClipList[iCurrentClipIndex]->\
749cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            ClipProperties.uiVideoWidth,
750cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->pEditSettings->pClipList[iCurrentClipIndex]->\
751cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            ClipProperties.uiVideoHeight,
752cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            &tnTimeMs);
753cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (result != M4NO_ERROR) {
754cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_free((M4OSA_MemAddr32)pixelArray);
755cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            ThumbnailClose(tnContext);
756cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            return -1;
757cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
758cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
759cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        ThumbnailClose(tnContext);
760cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        tnContext = M4OSA_NULL;
761cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
762cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#ifdef DUMPTOFILE
763cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
764cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_Context fileContext;
765cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_Char* fileName = (M4OSA_Char*)"/mnt/sdcard/FirstRGB565.raw";
766cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_fileExtraDelete((const M4OSA_Char *)fileName);
767cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_fileWriteOpen(&fileContext, (M4OSA_Void*) fileName,\
768cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_kFileWrite|M4OSA_kFileCreate);
769cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_fileWriteData(fileContext, (M4OSA_MemAddr8) pixelArray,
770cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                framesizeYuv);
771cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_fileWriteClose(fileContext);
772cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
773cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#endif
774cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
775cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        /**
776cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        * Allocate output YUV planes
777cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        */
778cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        yuvPlane = (M4VIFI_ImagePlane*)M4OSA_malloc(3*sizeof(M4VIFI_ImagePlane), M4VS,
779cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            (M4OSA_Char*)"videoEditor_renderPreviewFrame Output plane YUV");
780cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (yuvPlane == M4OSA_NULL) {
781cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR",
782cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                "videoEditor_renderPreviewFrame() malloc error for yuv plane");
783cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_free((M4OSA_MemAddr32)pixelArray);
784cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pMessage = videoEditJava_getErrorName(M4ERR_ALLOC);
785cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            jniThrowException(pEnv, "java/lang/RuntimeException", pMessage);
786cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            return -1;
787cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
788cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
789cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        yuvPlane[0].u_width = width;
790cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        yuvPlane[0].u_height = height;
791cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        yuvPlane[0].u_topleft = 0;
792cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        yuvPlane[0].u_stride = width;
793cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        yuvPlane[0].pac_data = (M4VIFI_UInt8*)pixelArray;
794cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
795cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        yuvPlane[1].u_width = width>>1;
796cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        yuvPlane[1].u_height = height>>1;
797cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        yuvPlane[1].u_topleft = 0;
798cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        yuvPlane[1].u_stride = width>>1;
799cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        yuvPlane[1].pac_data = yuvPlane[0].pac_data
800cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    + yuvPlane[0].u_width * yuvPlane[0].u_height;
801cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        yuvPlane[2].u_width = (width)>>1;
802cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        yuvPlane[2].u_height = (height)>>1;
803cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        yuvPlane[2].u_topleft = 0;
804cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        yuvPlane[2].u_stride = (width)>>1;
805cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        yuvPlane[2].pac_data = yuvPlane[1].pac_data
806cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    + yuvPlane[1].u_width * yuvPlane[1].u_height;
807cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
808cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#ifdef DUMPTOFILE
809cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
810cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_Context fileContext;
811cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_Char* fileName = (M4OSA_Char*)"/mnt/sdcard/ConvertedYuv.yuv";
812cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_fileExtraDelete((const M4OSA_Char *)fileName);
813cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_fileWriteOpen(&fileContext, (M4OSA_Void*) fileName,\
814cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_kFileWrite|M4OSA_kFileCreate);
815cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_fileWriteData(fileContext,
816cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                (M4OSA_MemAddr8) yuvPlane[0].pac_data, framesizeYuv);
817cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_fileWriteClose(fileContext);
818cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
819cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#endif
820cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
821cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        /* Fill up the render structure*/
822cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        frameStr.pBuffer = (M4OSA_Void*)yuvPlane[0].pac_data;
823cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
824cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
825cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    frameStr.timeMs = timeMs;    /* timestamp on storyboard*/
826cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    frameStr.uiSurfaceWidth =
827cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->pEditSettings->pClipList[iCurrentClipIndex]->\
828cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        ClipProperties.uiVideoWidth;
829cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    frameStr.uiSurfaceHeight =
830cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->pEditSettings->pClipList[iCurrentClipIndex]->\
831cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        ClipProperties.uiVideoHeight;
832cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    frameStr.uiFrameWidth =
833cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->pEditSettings->pClipList[iCurrentClipIndex]->\
834cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        ClipProperties.uiVideoWidth;
835cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    frameStr.uiFrameHeight =
836cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->pEditSettings->pClipList[iCurrentClipIndex]->\
837cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        ClipProperties.uiVideoHeight;
838cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pContext->pEditSettings->nbEffects > 0) {
839cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        frameStr.bApplyEffect = M4OSA_TRUE;
840cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    } else {
841cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        frameStr.bApplyEffect = M4OSA_FALSE;
842cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
843cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    frameStr.clipBeginCutTime = iIncrementedDuration;
844cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    frameStr.clipEndCutTime =
845cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        iIncrementedDuration +
846cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (pContext->pEditSettings->pClipList[iCurrentClipIndex]->uiEndCutTime -\
847cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->pEditSettings->pClipList[iCurrentClipIndex]->uiBeginCutTime);
848cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
849cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext->mPreviewController->setPreviewFrameRenderingMode(
850cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->pEditSettings->\
851cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pClipList[iCurrentClipIndex]->xVSS.MediaRendering,
852cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->pEditSettings->xVSS.outputVideoSize);
853cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    result = pContext->mPreviewController->renderPreviewFrame(previewSurface,
854c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                                                              &frameStr, &currEditInfo);
855c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
856c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    if (currEditInfo.overlaySettingsIndex != -1) {
857c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        char tmpOverlayFilename[100];
858c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        char *extPos = NULL;
859c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        jstring tmpOverlayString;
860c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        int tmpRenderingMode = 0;
861c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
862c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        strncpy (tmpOverlayFilename,
863c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                (const char*)pContext->pEditSettings->Effects[currEditInfo.overlaySettingsIndex].xVSS.pFramingFilePath, 99);
864c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
865c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        //Change the name to png file
866c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        extPos = strstr(tmpOverlayFilename, ".rgb");
867c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        if (extPos != NULL) {
868c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            *extPos = '\0';
869c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        } else {
870c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            LOGE("ERROR the overlay file is incorrect");
871c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        }
872c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
873c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        strcat(tmpOverlayFilename, ".png");
874c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
875c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        tmpRenderingMode = pContext->pEditSettings->pClipList[iCurrentClipIndex]->xVSS.MediaRendering;
876c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        tmpOverlayString = pEnv->NewStringUTF(tmpOverlayFilename);
877c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        pEnv->CallVoidMethod(pContext->engine,
878c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            pContext->previewFrameEditInfoId,
879c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            tmpOverlayString, tmpRenderingMode);
880c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
881c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    }
882c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
883cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv,
884cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            (M4NO_ERROR != result), result);
885cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
886cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pContext->pEditSettings->pClipList[iCurrentClipIndex]->FileType ==\
887cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi         /*M4VIDEOEDITING_kFileType_JPG */ M4VIDEOEDITING_kFileType_ARGB8888) {
888cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_free((M4OSA_MemAddr32)frameStr.pBuffer);
889cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    } else {
890cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_free((M4OSA_MemAddr32)yuvPlane[0].pac_data);
891cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_free((M4OSA_MemAddr32)yuvPlane);
892cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
893cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return tnTimeMs;
894cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
895cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
896cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic int videoEditor_renderMediaItemPreviewFrame(JNIEnv* pEnv,
897cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                    jobject thiz,
898cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                    jobject mSurface,
899cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                    jstring filePath,
900cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                    jint    frameWidth,
901cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                    jint    frameHeight,
902cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                    jint    surfaceWidth,
903cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                    jint    surfaceHeight,
904cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                    jlong   fromMs)
905cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
906cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool needToBeLoaded = true;
907cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR result = M4NO_ERROR;
908cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32 timeMs = (M4OSA_UInt32)fromMs;
909cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32 framesizeYuv =0;
910cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4VIFI_UInt8 *pixelArray = M4OSA_NULL;
911cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VideoEditor_renderPreviewFrameStr frameStr;
912cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Context tnContext = M4OSA_NULL;
913cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    const char* pMessage = NULL;
914cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4VIFI_ImagePlane yuvPlane[3], rgbPlane;
915cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
916cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditContext* pContext = M4OSA_NULL;
917cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Get the context.
918cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext =
919cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            (ManualEditContext*)videoEditClasses_getContext(&needToBeLoaded,
920cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                      pEnv, thiz);
921cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
922cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Make sure that the context was set.
923cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
924cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == pContext),
925cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
926cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
927cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Make sure that the context was set.
928cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
929cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 (M4OSA_NULL == pContext->mPreviewController),
930cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 "not initialized");
931cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
932cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Validate the mSurface parameter.
933cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalArgumentException(&needToBeLoaded, pEnv,
934cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                (NULL == mSurface),
935cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                "mSurface is null");
936cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jclass surfaceClass = pEnv->FindClass("android/view/Surface");
937cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
938cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == surfaceClass),
939cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
940cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
941cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jfieldID surface_native =
942cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pEnv->GetFieldID(surfaceClass, ANDROID_VIEW_SURFACE_JNI_ID, "I");
943cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
944cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == surface_native),
945cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
946cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
947cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    Surface* const p = (Surface*)pEnv->GetIntField(mSurface, surface_native);
948cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    sp<Surface> previewSurface = sp<Surface>(p);
949cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
950cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
951cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    const char *pString = pEnv->GetStringUTFChars(filePath, NULL);
952cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pString == M4OSA_NULL) {
953cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (pEnv != NULL) {
954cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            jniThrowException(pEnv, "java/lang/RuntimeException", "Input string null");
955cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
956cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
957cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR",
958cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        "videoEditor_renderMediaItemPreviewFrame() timeMs=%d", timeMs);
959cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* get thumbnail*/
960cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    result = ThumbnailOpen(&tnContext,(const M4OSA_Char*)pString, M4OSA_TRUE);
961cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (result != M4NO_ERROR || tnContext  == M4OSA_NULL) {
962cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        return timeMs;
963cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
964cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
965cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    framesizeYuv = ((frameWidth)*(frameHeight)*1.5);
966cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
967cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pixelArray = (M4VIFI_UInt8 *)M4OSA_malloc(framesizeYuv, M4VS,\
968cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4OSA_Char*)"videoEditor pixelArray");
969cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pixelArray == M4OSA_NULL) {
970cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR",
971cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            "videoEditor_renderPreviewFrame() malloc error");
972cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        ThumbnailClose(tnContext);
973cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pMessage = videoEditJava_getErrorName(M4ERR_ALLOC);
974cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        jniThrowException(pEnv, "java/lang/RuntimeException", pMessage);
975cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        return timeMs;
976cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
977cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
978cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    result = ThumbnailGetPixels16(tnContext, (M4OSA_Int16 *)pixelArray,
979cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                frameWidth,
980cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                frameHeight, &timeMs);
981cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (result != M4NO_ERROR) {
982cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_free((M4OSA_MemAddr32)pixelArray);
983cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        ThumbnailClose(tnContext);
984cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        return fromMs;
985cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
986cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
987cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#ifdef DUMPTOFILESYSTEM
988cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
989cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_Context fileContext;
990cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_Char* fileName = (M4OSA_Char*)"/mnt/sdcard/FirstRGB565.rgb";
991cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_fileWriteOpen(&fileContext, (M4OSA_Void*) fileName,\
992cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_kFileWrite|M4OSA_kFileCreate);
993cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_fileWriteData(fileContext, (M4OSA_MemAddr8) pixelArray,
994cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                            framesizeRgb);
995cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_fileWriteClose(fileContext);
996cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
997cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#endif
998cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
999cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    yuvPlane[0].pac_data = (M4VIFI_UInt8*)pixelArray;
1000cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    yuvPlane[0].u_height = frameHeight;
1001cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    yuvPlane[0].u_width = frameWidth;
1002cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    yuvPlane[0].u_stride = yuvPlane[0].u_width;
1003cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    yuvPlane[0].u_topleft = 0;
1004cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1005cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    yuvPlane[1].u_height = frameHeight/2;
1006cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    yuvPlane[1].u_width = frameWidth/2;
1007cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    yuvPlane[1].u_stride = yuvPlane[1].u_width;
1008cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    yuvPlane[1].u_topleft = 0;
1009cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    yuvPlane[1].pac_data = yuvPlane[0].pac_data
1010cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                + yuvPlane[0].u_width*yuvPlane[0].u_height;
1011cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1012cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    yuvPlane[2].u_height = frameHeight/2;
1013cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    yuvPlane[2].u_width = frameWidth/2;
1014cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    yuvPlane[2].u_stride = yuvPlane[2].u_width;
1015cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    yuvPlane[2].u_topleft = 0;
1016cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    yuvPlane[2].pac_data = yuvPlane[0].pac_data
1017cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        + yuvPlane[0].u_width*yuvPlane[0].u_height + \
1018cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (yuvPlane[0].u_width/2)*(yuvPlane[0].u_height/2);
1019cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#ifdef DUMPTOFILESYSTEM
1020cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
1021cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_Context fileContext;
1022cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_Char* fileName = (M4OSA_Char*)"/mnt/sdcard/ConvertedYuv.yuv";
1023cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_fileWriteOpen(&fileContext, (M4OSA_Void*) fileName,\
1024cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_kFileWrite|M4OSA_kFileCreate);
1025cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_fileWriteData(fileContext, (M4OSA_MemAddr8) yuvPlane[0].pac_data,
1026cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                            framesizeYuv);
1027cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_fileWriteClose(fileContext);
1028cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
1029cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi#endif
1030cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1031cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* Fill up the render structure*/
1032cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    frameStr.pBuffer = (M4OSA_Void*)yuvPlane[0].pac_data;
1033cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    frameStr.timeMs = timeMs;    /* timestamp on storyboard*/
1034cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    frameStr.uiSurfaceWidth = frameWidth;
1035cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    frameStr.uiSurfaceHeight = frameHeight;
1036cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    frameStr.uiFrameWidth = frameWidth;
1037cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    frameStr.uiFrameHeight = frameHeight;
1038cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    frameStr.bApplyEffect = M4OSA_FALSE;
1039cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // clip begin cuttime and end cuttime set to 0
1040cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // as its only required when effect needs to be applied while rendering
1041cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    frameStr.clipBeginCutTime = 0;
1042cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    frameStr.clipEndCutTime = 0;
1043cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1044cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /*  pContext->mPreviewController->setPreviewFrameRenderingMode(M4xVSS_kBlackBorders,
1045cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    (M4VIDEOEDITING_VideoFrameSize)(M4VIDEOEDITING_kHD960+1));*/
1046cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    result
1047c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    = pContext->mPreviewController->renderPreviewFrame(previewSurface,&frameStr, NULL);
1048cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv,
1049cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                (M4NO_ERROR != result), result);
1050cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1051cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* free the pixelArray and yuvPlane[0].pac_data */
1052cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_free((M4OSA_MemAddr32)yuvPlane[0].pac_data);
1053cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1054cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ThumbnailClose(tnContext);
1055cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1056cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return timeMs;
1057cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
1058cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1059cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargiint videoEditor_generateAudioRawFile(   JNIEnv*     pEnv,
1060cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                        jobject     thiz,
1061cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                        jstring     infilePath,
1062cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                        jstring     pcmfilePath)
1063cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
1064cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR result = M4NO_ERROR;
1065cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool               loaded   = true;
1066cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditContext* pContext = M4OSA_NULL;
1067cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1068cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1069cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1070cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    const char *pInputFile = pEnv->GetStringUTFChars(infilePath, NULL);
1071cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pInputFile == M4OSA_NULL) {
1072cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (pEnv != NULL) {
1073cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            jniThrowException(pEnv, "java/lang/RuntimeException", "Input string null");
1074cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
1075cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
1076cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1077cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    const char *pStringOutPCMFilePath = pEnv->GetStringUTFChars(pcmfilePath, NULL);
1078cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pStringOutPCMFilePath == M4OSA_NULL) {
1079cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (pEnv != NULL) {
1080cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            jniThrowException(pEnv, "java/lang/RuntimeException", "Input string null");
1081cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
1082cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
1083cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1084cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO,
1085cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        "VIDEO_EDITOR", "videoEditor_generateAudioRawFile infilePath %s",
1086cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pInputFile);
1087cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO,
1088cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        "VIDEO_EDITOR", "videoEditor_generateAudioRawFile pcmfilePath %s",
1089cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pStringOutPCMFilePath);
1090cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Get the context.
1091cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext = (ManualEditContext*)videoEditClasses_getContext(&loaded, pEnv, thiz);
1092cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1093cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    result = videoEditor_generateAudio( pEnv, pContext, (M4OSA_Char*)pInputFile,
1094cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4OSA_Char*)pStringOutPCMFilePath);
1095cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1096cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return result;
1097cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
1098cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1099cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargiM4OSA_ERR videoEditor_generateAudio(JNIEnv* pEnv,ManualEditContext* pContext,
1100cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    M4OSA_Char* infilePath,
1101cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    M4OSA_Char* pcmfilePath )
1102cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
1103cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool                            needToBeLoaded = true;
1104cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR                       result = M4NO_ERROR;
1105beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    M4MCS_Context                   mcsContext = M4OSA_NULL;
1106cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Char*                     pInputFile = M4OSA_NULL;
1107cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Char*                     pOutputFile = M4OSA_NULL;
1108cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Char*                     pTempPath = M4OSA_NULL;
1109cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4MCS_OutputParams*             pOutputParams = M4OSA_NULL;
1110cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4MCS_EncodingParams*           pEncodingParams = M4OSA_NULL;
1111cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Int32                     pInputFileType = 0;
1112cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt8                     threadProgress = 0;
1113cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Char*                     pTemp3gpFilePath = M4OSA_NULL;
1114cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1115cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR", "videoEditor_generateAudio()");
1116cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1117cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalArgumentException(&needToBeLoaded, pEnv,
1118cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (NULL == pContext),
1119cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        "ManualEditContext is null");
1120cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1121cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", "M4MCS_init()");
1122cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1123cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pOutputParams = (M4MCS_OutputParams *)M4OSA_malloc(
1124cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        sizeof(M4MCS_OutputParams),0x00,
1125cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4OSA_Char *)"M4MCS_OutputParams");
1126cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1127cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4OSA_NULL == pOutputParams),
1128cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        "not initialized");
1129beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    if (needToBeLoaded == false) {
1130beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        return M4ERR_ALLOC;
1131beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    }
1132cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1133cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pEncodingParams = (M4MCS_EncodingParams *)M4OSA_malloc(
1134cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        sizeof(M4MCS_EncodingParams),0x00,
1135cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4OSA_Char *)"M4MCS_EncodingParams");
1136cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1137cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4OSA_NULL == pEncodingParams),
1138cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        "not initialized");
1139beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    if (needToBeLoaded == false) {
1140beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        M4OSA_free((M4OSA_MemAddr32)pEncodingParams);
1141beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        pEncodingParams = M4OSA_NULL;
1142beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        return M4ERR_ALLOC;
1143beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    }
1144beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1145cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Initialize the MCS library.
1146cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    result = M4MCS_init(&mcsContext, pContext->initParams.pFileReadPtr,
1147cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->initParams.pFileWritePtr);
1148cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv,\
1149cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4NO_ERROR != result), result);
1150cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1151cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4OSA_NULL == mcsContext),
1152cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        "not initialized");
1153beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi     if(needToBeLoaded == false) {
1154beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pOutputParams);
1155beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pOutputParams = M4OSA_NULL;
1156beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pEncodingParams);
1157beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pEncodingParams = M4OSA_NULL;
1158beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         return result;
1159beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi     }
1160beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1161cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // generate the path for temp 3gp output file
1162cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pTemp3gpFilePath = (M4OSA_Char*) M4OSA_malloc (
1163cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4OSA_chrLength((M4OSA_Char*)pContext->initParams.pTempPath)
11645618e037af1a9d4323990a580d4181b9bc8e3091Dheeraj Sharma        + M4OSA_chrLength ((M4OSA_Char*)TEMP_MCS_OUT_FILE_PATH)) + 1 /* for null termination */ , 0x0,
1165cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4OSA_Char*) "Malloc for temp 3gp file");
1166cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if ( pTemp3gpFilePath != M4OSA_NULL )
1167cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
1168cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_memset(pTemp3gpFilePath  ,
1169cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_chrLength((M4OSA_Char*)pContext->initParams.pTempPath)
11705618e037af1a9d4323990a580d4181b9bc8e3091Dheeraj Sharma            + M4OSA_chrLength((M4OSA_Char*)TEMP_MCS_OUT_FILE_PATH) + 1, 0);
1171cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_chrNCat ( (M4OSA_Char*)pTemp3gpFilePath,
1172cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            (M4OSA_Char*)pContext->initParams.pTempPath  ,
1173cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_chrLength ((M4OSA_Char*)pContext->initParams.pTempPath));
1174cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_chrNCat ( pTemp3gpFilePath , (M4OSA_Char*)TEMP_MCS_OUT_FILE_PATH,
1175cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_chrLength ((M4OSA_Char*)TEMP_MCS_OUT_FILE_PATH));
1176cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
1177beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    else {
1178beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4MCS_abort(mcsContext);
1179beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pOutputParams);
1180beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pOutputParams = M4OSA_NULL;
1181beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pEncodingParams);
1182beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pEncodingParams = M4OSA_NULL;
1183beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         return M4ERR_ALLOC;
1184beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    }
1185cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1186cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pInputFile = (M4OSA_Char *) infilePath; //pContext->mAudioSettings->pFile;
1187cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    //Delete this file later
1188cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pOutputFile = (M4OSA_Char *) pTemp3gpFilePath;
1189cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Temp folder path for VSS use = ProjectPath
1190cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pTempPath = (M4OSA_Char *) pContext->initParams.pTempPath;
1191cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pInputFileType = (M4VIDEOEDITING_FileType)pContext->mAudioSettings->fileType;
1192cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1193cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR", "TEMP_MCS_OUT_FILE_PATH len %d",
1194cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_chrLength ((M4OSA_Char*)TEMP_MCS_OUT_FILE_PATH));
1195cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR", "pTemp3gpFilePath %s",
1196cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pOutputFile);
1197cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1198cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR", "M4MCS_open()");
1199cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1200cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    result = M4MCS_open(mcsContext, pInputFile,
1201cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4VIDEOEDITING_FileType)pInputFileType,
1202cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pOutputFile, pTempPath);
1203cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv,
1204cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4NO_ERROR != result), result);
1205beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    if(needToBeLoaded == false) {
1206beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pTemp3gpFilePath);
1207beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pTemp3gpFilePath = M4OSA_NULL;
1208beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4MCS_abort(mcsContext);
1209beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pOutputParams);
1210beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pOutputParams = M4OSA_NULL;
1211beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pEncodingParams);
1212beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pEncodingParams = M4OSA_NULL;
1213beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         return result;
1214beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    }
1215cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1216cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pOutputParams->OutputFileType
1217cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        = (M4VIDEOEDITING_FileType)M4VIDEOEDITING_kFileType_3GPP;
1218cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the video format.
1219cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pOutputParams->OutputVideoFormat =
1220cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4VIDEOEDITING_VideoFormat)M4VIDEOEDITING_kNoneVideo;//M4VIDEOEDITING_kNoneVideo;
1221cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the frame size.
1222cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pOutputParams->OutputVideoFrameSize
1223cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        = (M4VIDEOEDITING_VideoFrameSize)M4VIDEOEDITING_kQCIF;
1224cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the frame rate.
1225cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pOutputParams->OutputVideoFrameRate
1226cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        = (M4VIDEOEDITING_VideoFramerate)M4VIDEOEDITING_k5_FPS;
1227cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1228cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the audio format.
1229cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pOutputParams->OutputAudioFormat
1230cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        = (M4VIDEOEDITING_AudioFormat)M4VIDEOEDITING_kAAC;
1231cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the audio sampling frequency.
1232cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pOutputParams->OutputAudioSamplingFrequency =
1233cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4VIDEOEDITING_AudioSamplingFrequency)M4VIDEOEDITING_k32000_ASF;
1234cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the audio mono.
1235cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pOutputParams->bAudioMono = false;
1236cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the pcm file; null for now.
1237cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pOutputParams->pOutputPCMfile = (M4OSA_Char *)pcmfilePath;
1238cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    //(M4OSA_Char *)"/sdcard/Output/AudioPcm.pcm";
1239cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the audio sampling frequency.
1240cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pOutputParams->MediaRendering = (M4MCS_MediaRendering)M4MCS_kCropping;
1241cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // new params after integrating MCS 2.0
1242cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the number of audio effects; 0 for now.
1243cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pOutputParams->nbEffects = 0;
1244cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the audio effect; null for now.
1245cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pOutputParams->pEffects = NULL;
1246cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the audio effect; null for now.
1247cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pOutputParams->bDiscardExif = M4OSA_FALSE;
1248cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the audio effect; null for now.
1249cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pOutputParams->bAdjustOrientation = M4OSA_FALSE;
1250cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1251cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", "M4MCS_setOutputParams()");
1252cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    result = M4MCS_setOutputParams(mcsContext, pOutputParams);
1253cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv,
1254cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                        (M4NO_ERROR != result), result);
1255beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    if (needToBeLoaded == false) {
1256beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pTemp3gpFilePath);
1257beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pTemp3gpFilePath = M4OSA_NULL;
1258beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4MCS_abort(mcsContext);
1259beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pOutputParams);
1260beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pOutputParams = M4OSA_NULL;
1261beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pEncodingParams);
1262beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pEncodingParams = M4OSA_NULL;
1263beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        return result;
1264beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    }
1265cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the video bitrate.
1266cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pEncodingParams->OutputVideoBitrate =
1267cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    (M4VIDEOEDITING_Bitrate)M4VIDEOEDITING_kUndefinedBitrate;
1268cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the audio bitrate.
1269cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pEncodingParams->OutputAudioBitrate
1270cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        = (M4VIDEOEDITING_Bitrate)M4VIDEOEDITING_k128_KBPS;
1271cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the end cut time in milliseconds.
1272cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pEncodingParams->BeginCutTime = 0;
1273cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the end cut time in milliseconds.
1274cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pEncodingParams->EndCutTime = 0;
1275cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the output file size in bytes.
1276cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pEncodingParams->OutputFileSize = 0;
1277cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set video time scale.
1278cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pEncodingParams->OutputVideoTimescale = 0;
1279cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1280cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR",
1281cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                            "M4MCS_setEncodingParams()");
1282cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    result = M4MCS_setEncodingParams(mcsContext, pEncodingParams);
1283cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv,
1284cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4NO_ERROR != result), result);
1285beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    if (needToBeLoaded == false) {
1286beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pTemp3gpFilePath);
1287beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pTemp3gpFilePath = M4OSA_NULL;
1288beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4MCS_abort(mcsContext);
1289beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pOutputParams);
1290beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pOutputParams = M4OSA_NULL;
1291beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pEncodingParams);
1292beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pEncodingParams = M4OSA_NULL;
1293beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         return result;
1294beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    }
1295cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1296cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR",
1297cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                            "M4MCS_checkParamsAndStart()");
1298cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    result = M4MCS_checkParamsAndStart(mcsContext);
1299cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv,
1300cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4NO_ERROR != result), result);
1301beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    if (needToBeLoaded == false) {
1302beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pTemp3gpFilePath);
1303beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pTemp3gpFilePath = M4OSA_NULL;
1304beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4MCS_abort(mcsContext);
1305beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pOutputParams);
1306beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pOutputParams = M4OSA_NULL;
1307beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pEncodingParams);
1308beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pEncodingParams = M4OSA_NULL;
1309beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        return result;
1310beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    }
1311cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1312cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", "M4MCS_step()");
1313cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1314cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /*+ PROGRESS CB */
1315cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt8 curProgress = 0;
1316cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    int         lastProgress = 0;
1317cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1318cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    LOGV("LVME_generateAudio Current progress is =%d", curProgress);
1319cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pEnv->CallVoidMethod(pContext->engine,
1320cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->onProgressUpdateMethodId, 1/*task status*/,
1321cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            curProgress/*progress*/);
1322cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    do {
1323cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        result = M4MCS_step(mcsContext, &curProgress);
1324cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1325cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (result != M4NO_ERROR) {
1326cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            LOGV("LVME_generateAudio M4MCS_step returned 0x%x",result);
1327cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1328cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            if (result == M4MCS_WAR_TRANSCODING_DONE) {
1329cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                LOGV("LVME_generateAudio MCS process ended");
1330cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1331cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                // Send a progress notification.
1332cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                curProgress = 100;
1333cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                pEnv->CallVoidMethod(pContext->engine,
1334cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    pContext->onProgressUpdateMethodId, 1/*task status*/,
1335cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    curProgress);
1336cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                LOGV("LVME_generateAudio Current progress is =%d", curProgress);
1337cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            }
1338cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        } else {
1339cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Send a progress notification if needed
1340cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            if (curProgress != lastProgress) {
1341cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                lastProgress = curProgress;
1342cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                pEnv->CallVoidMethod(pContext->engine,
1343cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    pContext->onProgressUpdateMethodId, 0/*task status*/,
1344cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    curProgress/*progress*/);
1345cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                LOGV("LVME_generateAudio Current progress is =%d",curProgress);
1346cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            }
1347cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
1348cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    } while (result == M4NO_ERROR);
1349cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /*- PROGRESS CB */
1350cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1351cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv,
1352cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4MCS_WAR_TRANSCODING_DONE != result), result);
1353beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    if (needToBeLoaded == false) {
1354beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pTemp3gpFilePath);
1355beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pTemp3gpFilePath = M4OSA_NULL;
1356beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4MCS_abort(mcsContext);
1357beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pOutputParams);
1358beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pOutputParams = M4OSA_NULL;
1359beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         M4OSA_free((M4OSA_MemAddr32)pEncodingParams);
1360beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi         pEncodingParams = M4OSA_NULL;
1361beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        return result;
1362beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    }
1363cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1364cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", "M4MCS_abort()");
1365cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    result = M4MCS_abort(mcsContext);
1366cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv,
1367cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4NO_ERROR != result), result);
1368cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1369cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    //pContext->mAudioSettings->pFile = pOutputParams->pOutputPCMfile;
1370cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_fileExtraDelete((const M4OSA_Char *) pTemp3gpFilePath);
1371cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", "videoEditor_generateAudio() EXIT ");
1372cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1373beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    if (pTemp3gpFilePath != M4OSA_NULL) {
1374beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        M4OSA_free((M4OSA_MemAddr32)pTemp3gpFilePath);
1375beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    }
1376beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    if (pOutputParams != M4OSA_NULL) {
1377beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi       M4OSA_free((M4OSA_MemAddr32)pOutputParams);
1378beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    }
1379beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    if(pEncodingParams != M4OSA_NULL) {
1380beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi       M4OSA_free((M4OSA_MemAddr32)pEncodingParams);
1381beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    }
1382cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return result;
1383cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
1384cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1385cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic int removeAlphafromRGB8888 (
1386cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                        M4OSA_Char* pFramingFilePath,
1387cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                        M4xVSS_FramingStruct *pFramingCtx)
1388cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
1389cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32 frameSize_argb = (pFramingCtx->width * pFramingCtx->height * 4); // aRGB data
1390cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Context lImageFileFp  = M4OSA_NULL;
1391cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR err = M4NO_ERROR;
1392cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1393cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    LOGV("removeAlphafromRGB8888: width %d", pFramingCtx->width);
1394cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1395cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt8 *pTmpData = (M4OSA_UInt8*) M4OSA_malloc(frameSize_argb, M4VS, (M4OSA_Char*)"Image argb data");
1396cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pTmpData == M4OSA_NULL) {
1397cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        LOGE("Failed to allocate memory for Image clip");
1398cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        return M4ERR_ALLOC;
1399cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
1400cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1401cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi       /** Read the argb data from the passed file. */
1402cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR lerr = M4OSA_fileReadOpen(&lImageFileFp, (M4OSA_Void *) pFramingFilePath, M4OSA_kFileRead);
1403cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1404cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1405cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if ((lerr != M4NO_ERROR) || (lImageFileFp == M4OSA_NULL))
1406cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
1407cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        LOGE("removeAlphafromRGB8888: Can not open the file ");
1408cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_free((M4OSA_MemAddr32)pTmpData);
1409cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        return M4ERR_FILE_NOT_FOUND;
1410cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
1411cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1412cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1413cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    lerr = M4OSA_fileReadData(lImageFileFp, (M4OSA_MemAddr8)pTmpData, &frameSize_argb);
1414cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (lerr != M4NO_ERROR)
1415cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
1416cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        LOGE("removeAlphafromRGB8888: can not read the data ");
1417cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_fileReadClose(lImageFileFp);
1418cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_free((M4OSA_MemAddr32)pTmpData);
1419cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        return lerr;
1420cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
1421cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_fileReadClose(lImageFileFp);
1422cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1423cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32 frameSize = (pFramingCtx->width * pFramingCtx->height * 3); //Size of RGB 888 data.
1424cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1425cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pFramingCtx->FramingRgb = (M4VIFI_ImagePlane*)M4OSA_malloc(
1426cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi             sizeof(M4VIFI_ImagePlane), M4VS, (M4OSA_Char*)"Image clip RGB888 data");
1427cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pFramingCtx->FramingRgb->pac_data = (M4VIFI_UInt8*)M4OSA_malloc(
1428cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi             frameSize, M4VS, (M4OSA_Char*)"Image clip RGB888 data");
1429cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1430cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pFramingCtx->FramingRgb == M4OSA_NULL)
1431cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
1432cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        LOGE("Failed to allocate memory for Image clip");
1433cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_free((M4OSA_MemAddr32)pTmpData);
1434cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        return M4ERR_ALLOC;
1435cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
1436cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1437cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /** Remove the alpha channel */
1438581cad2221cb367e9e3ef6991c565cd37ced994fJames Dong    for (size_t i = 0, j = 0; i < frameSize_argb; i++) {
1439cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if ((i % 4) == 0) continue;
1440cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pFramingCtx->FramingRgb->pac_data[j] = pTmpData[i];
1441cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        j++;
1442cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
1443cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_free((M4OSA_MemAddr32)pTmpData);
1444cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return M4NO_ERROR;
1445cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
1446cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1447cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void
1448cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_populateSettings(
1449cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                 pEnv,
1450cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                 thiz,
1451cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                 settings,
1452cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                 object,
1453cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                 audioSettingObject)
1454cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
1455cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR",
1456cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            "videoEditor_populateSettings()");
1457cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1458cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool                needToBeLoaded  = true;
1459cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditContext*  pContext        = M4OSA_NULL;
1460cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR           result          = M4NO_ERROR;
1461cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jstring             str             = M4OSA_NULL;
1462cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jobjectArray        propertiesClipsArray           = M4OSA_NULL;
1463cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jobject             properties      = M4OSA_NULL;
1464cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jint*               bitmapArray     =  M4OSA_NULL;
1465cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jobjectArray        effectSettingsArray = M4OSA_NULL;
1466cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jobject             effectSettings  = M4OSA_NULL;
1467cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jintArray           pixelArray      = M4OSA_NULL;
1468cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    int width = 0;
1469cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    int height = 0;
1470cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    int nbOverlays = 0;
1471cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    int i,j = 0;
1472cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    int *pOverlayIndex = M4OSA_NULL;
1473cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1474cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Add a code marker (the condition must always be true).
1475cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ADD_CODE_MARKER_FUN(NULL != pEnv)
1476cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1477cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Validate the settings parameter.
1478cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalArgumentException(&needToBeLoaded, pEnv,
1479cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                (NULL == settings),
1480cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                "settings is null");
1481cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Get the context.
1482cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext =
1483cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            (ManualEditContext*)videoEditClasses_getContext(&needToBeLoaded, pEnv, thiz);
1484cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1485cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Make sure that the context was set.
1486cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1487cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == pContext),
1488cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
1489cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Make sure that the context was set.
1490cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1491cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 (M4OSA_NULL == pContext->mPreviewController),
1492cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 "not initialized");
1493cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jclass mPreviewClipPropClazz = pEnv->FindClass(PREVIEW_PROPERTIES_CLASS_NAME);
1494cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1495cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     (M4OSA_NULL == mPreviewClipPropClazz),
1496cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     "not initialized");
1497cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1498cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jfieldID fid = pEnv->GetFieldID(mPreviewClipPropClazz,"clipProperties",
1499cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            "[L"PROPERTIES_CLASS_NAME";"  );
1500cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1501cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     (M4OSA_NULL == fid),
1502cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     "not initialized");
1503cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1504cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    propertiesClipsArray = (jobjectArray)pEnv->GetObjectField(object, fid);
1505cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1506cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     (M4OSA_NULL == propertiesClipsArray),
1507cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     "not initialized");
1508cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1509cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jclass engineClass = pEnv->FindClass(MANUAL_EDIT_ENGINE_CLASS_NAME);
1510cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1511cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     (M4OSA_NULL == engineClass),
1512cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     "not initialized");
1513cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1514cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext->onPreviewProgressUpdateMethodId = pEnv->GetMethodID(engineClass,
1515c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            "onPreviewProgressUpdate",     "(IZZLjava/lang/String;I)V");
1516cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Check if the context is valid (required because the context is dereferenced).
1517cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (needToBeLoaded) {
1518cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Make sure that we are in a correct state.
1519cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1520cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                             (pContext->state != ManualEditState_INITIALIZED),
1521cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                             "settings already loaded");
1522beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        if (needToBeLoaded) {
1523beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            // Retrieve the edit settings.
1524beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            if (pContext->pEditSettings != M4OSA_NULL) {
1525beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                videoEditClasses_freeEditSettings(&pContext->pEditSettings);
1526beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                pContext->pEditSettings = M4OSA_NULL;
1527beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            }
1528beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            videoEditClasses_getEditSettings(&needToBeLoaded, pEnv,
1529beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                settings, &pContext->pEditSettings,false);
1530cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
1531cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
1532beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1533beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    if (needToBeLoaded == false) {
1534beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        j = 0;
1535beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        while (j < pContext->pEditSettings->nbEffects)
1536beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        {
1537beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            if (pContext->pEditSettings->Effects[j].xVSS.pFramingFilePath != M4OSA_NULL) {
1538beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                if (pContext->pEditSettings->Effects[j].xVSS.pFramingBuffer != M4OSA_NULL) {
1539beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                    M4OSA_free((M4OSA_MemAddr32)pContext->pEditSettings->\
1540beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                    Effects[j].xVSS.pFramingBuffer);
1541beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                    pContext->pEditSettings->Effects[j].xVSS.pFramingBuffer = M4OSA_NULL;
1542beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                }
1543beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            }
1544beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi          j++;
1545beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        }
1546beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        return;
1547beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    }
1548beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1549cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_TRACE1_0("videoEditorC_getEditSettings done");
1550cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1551c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi    pContext->previewFrameEditInfoId = pEnv->GetMethodID(engineClass,
1552c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi        "previewFrameEditInfo", "(Ljava/lang/String;I)V");
1553c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi
1554cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if ( pContext->pEditSettings != NULL )
1555cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
1556cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if the edit settings could be retrieved.
1557cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        jclass mEditClazz = pEnv->FindClass(EDIT_SETTINGS_CLASS_NAME);
1558cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if(mEditClazz == M4OSA_NULL)
1559cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
1560cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_TRACE1_0("cannot find object field for mEditClazz");
1561beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            goto videoEditor_populateSettings_cleanup;
1562cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
1563cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        jclass mEffectsClazz = pEnv->FindClass(EFFECT_SETTINGS_CLASS_NAME);
1564cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if(mEffectsClazz == M4OSA_NULL)
1565cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
1566cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_TRACE1_0("cannot find object field for mEffectsClazz");
1567beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            goto videoEditor_populateSettings_cleanup;
1568cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
1569cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        fid = pEnv->GetFieldID(mEditClazz,"effectSettingsArray", "[L"EFFECT_SETTINGS_CLASS_NAME";"  );
1570cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if(fid == M4OSA_NULL)
1571cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
1572cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_TRACE1_0("cannot find field for effectSettingsArray Array");
1573beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            goto videoEditor_populateSettings_cleanup;
1574cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
1575cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        effectSettingsArray = (jobjectArray)pEnv->GetObjectField(settings, fid);
1576cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if(effectSettingsArray == M4OSA_NULL)
1577cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
1578cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_TRACE1_0("cannot find object field for effectSettingsArray");
1579beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            goto videoEditor_populateSettings_cleanup;
1580cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
1581beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1582cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        //int overlayIndex[pContext->pEditSettings->nbEffects];
1583beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        if (pContext->pEditSettings->nbEffects > 0)
1584cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
1585cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pOverlayIndex
1586c08f85a6484ee5da7062a5eac0f19912bd7e2513Dharmaray Kundargi            = (int*) M4OSA_malloc(pContext->pEditSettings->nbEffects * sizeof(int), 0,
1587cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                (M4OSA_Char*)"pOverlayIndex");
1588beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            if (pOverlayIndex == M4OSA_NULL) {
1589beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv,
1590beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                    M4OSA_TRUE, M4ERR_ALLOC);
1591beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                goto videoEditor_populateSettings_cleanup;
1592beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            }
1593cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
1594cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1595beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        i = 0;
1596beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        j = 0;
1597cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_TRACE1_1("no of effects = %d",pContext->pEditSettings->nbEffects);
1598cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        while (j < pContext->pEditSettings->nbEffects)
1599cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
1600cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            if (pContext->pEditSettings->Effects[j].xVSS.pFramingFilePath != M4OSA_NULL)
1601cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            {
1602cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                pOverlayIndex[nbOverlays] = j;
1603beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1604cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4xVSS_FramingStruct *aFramingCtx = M4OSA_NULL;
1605cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                aFramingCtx
1606cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                = (M4xVSS_FramingStruct*)M4OSA_malloc(sizeof(M4xVSS_FramingStruct), M4VS,
1607cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                  (M4OSA_Char*)"M4xVSS_internalDecodeGIF: Context of the framing effect");
1608cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                if (aFramingCtx == M4OSA_NULL)
1609cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                {
1610cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    M4OSA_TRACE1_0("Allocation error in videoEditor_populateSettings");
1611beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                    videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv,
1612beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                        M4OSA_TRUE, M4ERR_ALLOC);
1613beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                    goto videoEditor_populateSettings_cleanup;
1614cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                }
1615beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1616cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                aFramingCtx->pCurrent = M4OSA_NULL; /* Only used by the first element of the chain */
1617cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                aFramingCtx->previousClipTime = -1;
1618cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                aFramingCtx->FramingYuv = M4OSA_NULL;
1619cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                aFramingCtx->FramingRgb = M4OSA_NULL;
1620cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                aFramingCtx->topleft_x
1621cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    = pContext->pEditSettings->Effects[j].xVSS.topleft_x;
1622cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                aFramingCtx->topleft_y
1623cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    = pContext->pEditSettings->Effects[j].xVSS.topleft_y;
1624cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1625cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1626cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                 VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", "OF u_width %d",
1627cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                        pContext->pEditSettings->Effects[j].xVSS.pFramingBuffer->u_width);
1628cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                 VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", "OF u_height() %d",
1629cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                        pContext->pEditSettings->Effects[j].xVSS.pFramingBuffer->u_height);
1630cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                 VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", "OF rgbType() %d",
1631cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                        pContext->pEditSettings->Effects[j].xVSS.rgbType);
1632cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1633cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                 aFramingCtx->width = pContext->pEditSettings->Effects[j].xVSS.pFramingBuffer->u_width;
1634cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                 aFramingCtx->height = pContext->pEditSettings->Effects[j].xVSS.pFramingBuffer->u_height;
1635cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1636cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                result = M4xVSS_internalConvertARGB888toYUV420_FrammingEffect(pContext->engineContext,
1637cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    &(pContext->pEditSettings->Effects[j]),aFramingCtx,
1638cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                pContext->pEditSettings->Effects[j].xVSS.framingScaledSize);
1639c08f85a6484ee5da7062a5eac0f19912bd7e2513Dharmaray Kundargi                videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv,
1640c08f85a6484ee5da7062a5eac0f19912bd7e2513Dharmaray Kundargi                                            (M4NO_ERROR != result), result);
1641c08f85a6484ee5da7062a5eac0f19912bd7e2513Dharmaray Kundargi                if (needToBeLoaded == false) {
1642cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    M4OSA_TRACE1_1("M4xVSS_internalConvertARGB888toYUV420_FrammingEffect returned 0x%x", result);
1643c08f85a6484ee5da7062a5eac0f19912bd7e2513Dharmaray Kundargi                    if (aFramingCtx != M4OSA_NULL) {
1644c08f85a6484ee5da7062a5eac0f19912bd7e2513Dharmaray Kundargi                        M4OSA_free((M4OSA_MemAddr32)aFramingCtx);
1645c08f85a6484ee5da7062a5eac0f19912bd7e2513Dharmaray Kundargi                        aFramingCtx = M4OSA_NULL;
1646c08f85a6484ee5da7062a5eac0f19912bd7e2513Dharmaray Kundargi                    }
1647beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                    goto videoEditor_populateSettings_cleanup;
1648cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                }
1649cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1650cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                //framing buffers are resized to fit the output video resolution.
1651cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                pContext->pEditSettings->Effects[j].xVSS.pFramingBuffer->u_width =
1652cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    aFramingCtx->FramingRgb->u_width;
1653cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                pContext->pEditSettings->Effects[j].xVSS.pFramingBuffer->u_height =
1654cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    aFramingCtx->FramingRgb->u_height;
1655cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1656cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", "A framing Context aFramingCtx->width = %d",
1657cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    aFramingCtx->FramingRgb->u_width);
1658cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1659cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", "A framing Context aFramingCtx->height = %d",
1660cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    aFramingCtx->FramingRgb->u_height);
1661cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1662cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1663cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                width = pContext->pEditSettings->Effects[j].xVSS.pFramingBuffer->u_width;
1664cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                height = pContext->pEditSettings->Effects[j].xVSS.pFramingBuffer->u_height;
1665cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1666c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                //RGB 565
1667beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                pContext->pEditSettings->Effects[j].xVSS.pFramingBuffer->u_stride = width * 2;
1668cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1669c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                //for RGB565
1670cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                pContext->pEditSettings->Effects[j].xVSS.pFramingBuffer->u_topleft = 0;
1671cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                pContext->pEditSettings->Effects[j].xVSS.pFramingBuffer->pac_data =
1672c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                            (M4VIFI_UInt8 *)M4OSA_malloc(width*height*2,
1673c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                            0x00,(M4OSA_Char *)"pac_data buffer");
1674cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1675beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                if (pContext->pEditSettings->Effects[j].xVSS.pFramingBuffer->pac_data == M4OSA_NULL) {
1676beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                    M4OSA_TRACE1_0("Failed to allocate memory for framing buffer");
1677beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                    videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv,
1678beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                                            M4OSA_TRUE, M4ERR_ALLOC);
1679beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                    goto videoEditor_populateSettings_cleanup;
1680beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                }
1681beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1682cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_memcpy((M4OSA_Int8 *)&pContext->pEditSettings->\
1683cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    Effects[j].xVSS.pFramingBuffer->\
1684c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                    pac_data[0],(M4OSA_Int8 *)&aFramingCtx->FramingRgb->pac_data[0],(width*height*2));
1685cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1686c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                //As of now rgb type is 565
1687cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                pContext->pEditSettings->Effects[j].xVSS.rgbType =
1688c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi                    (M4VSS3GPP_RGBType) M4VSS3GPP_kRGB565;
1689cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1690cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                if (aFramingCtx->FramingYuv != M4OSA_NULL )
1691cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                {
1692cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    if (aFramingCtx->FramingYuv->pac_data != M4OSA_NULL) {
1693cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                        M4OSA_free((M4OSA_MemAddr32)aFramingCtx->FramingYuv->pac_data);
1694cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                        aFramingCtx->FramingYuv->pac_data = M4OSA_NULL;
1695cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    }
1696cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                }
1697cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                if (aFramingCtx->FramingYuv != M4OSA_NULL) {
1698cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    M4OSA_free((M4OSA_MemAddr32)aFramingCtx->FramingYuv);
1699cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    aFramingCtx->FramingYuv = M4OSA_NULL;
1700cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                }
1701cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                if (aFramingCtx->FramingRgb->pac_data != M4OSA_NULL) {
1702cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    M4OSA_free((M4OSA_MemAddr32)aFramingCtx->FramingRgb->pac_data);
1703cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    aFramingCtx->FramingRgb->pac_data = M4OSA_NULL;
1704cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                }
1705cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                if (aFramingCtx->FramingRgb != M4OSA_NULL) {
1706cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    M4OSA_free((M4OSA_MemAddr32)aFramingCtx->FramingRgb);
1707cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    aFramingCtx->FramingRgb = M4OSA_NULL;
1708cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                }
1709cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                if (aFramingCtx != M4OSA_NULL) {
1710cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    M4OSA_free((M4OSA_MemAddr32)aFramingCtx);
1711cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    aFramingCtx = M4OSA_NULL;
1712cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                }
1713beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                nbOverlays++;
1714cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            }
1715cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            j++;
1716cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
1717cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1718cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if the edit settings could be retrieved.
1719cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_TRACE1_1("total clips are = %d",pContext->pEditSettings->uiClipNumber);
1720cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        for (i = 0; i < pContext->pEditSettings->uiClipNumber; i++) {
1721cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_TRACE1_1("clip no = %d",i);
1722cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            properties = pEnv->GetObjectArrayElement(propertiesClipsArray, i);
1723cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1724cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                (M4OSA_NULL == properties),
1725cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                "not initialized");
1726beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            if (needToBeLoaded) {
1727beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                getClipSetting(pEnv,properties, pContext->pEditSettings->pClipList[i]);
1728beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            } else {
1729beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                goto videoEditor_populateSettings_cleanup;
1730beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            }
1731cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
1732cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1733cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (needToBeLoaded) {
1734cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Log the edit settings.
1735cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            VIDEOEDIT_LOG_EDIT_SETTINGS(pContext->pEditSettings);
1736cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
1737cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
1738cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1739cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (audioSettingObject != M4OSA_NULL) {
1740cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        jclass audioSettingClazz = pEnv->FindClass(AUDIO_SETTINGS_CLASS_NAME);
1741cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1742cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                         (M4OSA_NULL == audioSettingClazz),
1743cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                         "not initialized");
1744cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1745cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1746cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     (M4OSA_NULL == pContext->mAudioSettings),
1747cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     "not initialized");
1748cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1749beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        if (needToBeLoaded == false) {
1750beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            goto videoEditor_populateSettings_cleanup;
1751beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        }
1752beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1753cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        fid = pEnv->GetFieldID(audioSettingClazz,"bRemoveOriginal","Z");
1754cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->bRemoveOriginal = pEnv->GetIntField(audioSettingObject,fid);
1755cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_TRACE1_1("bRemoveOriginal = %d",pContext->mAudioSettings->bRemoveOriginal);
1756cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1757cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        fid = pEnv->GetFieldID(audioSettingClazz,"channels","I");
1758cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->uiNbChannels = pEnv->GetIntField(audioSettingObject,fid);
1759cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_TRACE1_1("uiNbChannels = %d",pContext->mAudioSettings->uiNbChannels);
1760cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1761cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        fid = pEnv->GetFieldID(audioSettingClazz,"Fs","I");
1762cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->uiSamplingFrequency = pEnv->GetIntField(audioSettingObject,fid);
1763cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_TRACE1_1("uiSamplingFrequency = %d",pContext->mAudioSettings->uiSamplingFrequency);
1764cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1765cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        fid = pEnv->GetFieldID(audioSettingClazz,"ExtendedFs","I");
1766cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->uiExtendedSamplingFrequency =
1767cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi         pEnv->GetIntField(audioSettingObject,fid);
1768cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_TRACE1_1("uiExtendedSamplingFrequency = %d",
1769cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->uiExtendedSamplingFrequency);
1770cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1771cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        fid = pEnv->GetFieldID(audioSettingClazz,"startMs","J");
1772cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->uiAddCts
1773cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            = pEnv->GetIntField(audioSettingObject,fid);
1774cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_TRACE1_1("uiAddCts = %d",pContext->mAudioSettings->uiAddCts);
1775cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1776cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        fid = pEnv->GetFieldID(audioSettingClazz,"volume","I");
1777cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->uiAddVolume
1778cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            = pEnv->GetIntField(audioSettingObject,fid);
1779cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_TRACE1_1("uiAddVolume = %d",pContext->mAudioSettings->uiAddVolume);
1780cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1781cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        fid = pEnv->GetFieldID(audioSettingClazz,"loop","Z");
1782cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->bLoop
1783cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            = pEnv->GetIntField(audioSettingObject,fid);
1784cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_TRACE1_1("bLoop = %d",pContext->mAudioSettings->bLoop);
1785cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1786cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        fid = pEnv->GetFieldID(audioSettingClazz,"beginCutTime","J");
1787cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->beginCutMs
1788cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            = pEnv->GetIntField(audioSettingObject,fid);
1789cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_TRACE1_1("begin cut time = %d",pContext->mAudioSettings->beginCutMs);
1790cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1791cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        fid = pEnv->GetFieldID(audioSettingClazz,"endCutTime","J");
1792cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->endCutMs
1793cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            = pEnv->GetIntField(audioSettingObject,fid);
1794cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_TRACE1_1("end cut time = %d",pContext->mAudioSettings->endCutMs);
1795cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1796cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        fid = pEnv->GetFieldID(audioSettingClazz,"fileType","I");
1797cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->fileType
1798cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            = pEnv->GetIntField(audioSettingObject,fid);
1799cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_TRACE1_1("fileType = %d",pContext->mAudioSettings->fileType);
1800cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        fid = pEnv->GetFieldID(audioSettingClazz,"pFile","Ljava/lang/String;");
1801cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        str = (jstring)pEnv->GetObjectField(audioSettingObject,fid);
1802cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->pFile
1803cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                = (M4OSA_Char*)pEnv->GetStringUTFChars(str, M4OSA_NULL);
1804cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_TRACE1_1("file name = %s",pContext->mAudioSettings->pFile);
1805cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEOEDITOR", "regenerateAudio() file name = %s",\
1806cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->pFile);
1807beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1808cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        fid = pEnv->GetFieldID(audioSettingClazz,"pcmFilePath","Ljava/lang/String;");
1809cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        str = (jstring)pEnv->GetObjectField(audioSettingObject,fid);
1810beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1811cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->pPCMFilePath =
1812cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4OSA_Char*)pEnv->GetStringUTFChars(str, M4OSA_NULL);
1813beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1814cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEOEDITOR", "pPCMFilePath -- %s ",\
1815cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->pPCMFilePath);
1816beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1817cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        fid = pEnv->GetFieldID(engineClass,"mRegenerateAudio","Z");
1818cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        bool regenerateAudio = pEnv->GetBooleanField(thiz,fid);
1819beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1820cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEOEDITOR", "regenerateAudio -- %d ",\
1821cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        regenerateAudio);
1822beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1823cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (regenerateAudio) {
1824cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_TRACE1_0("Calling Generate Audio now");
1825cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            result = videoEditor_generateAudio(pEnv,
1826cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                        pContext,
1827cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                        (M4OSA_Char*)pContext->mAudioSettings->pFile,
1828cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                        (M4OSA_Char*)pContext->mAudioSettings->pPCMFilePath);
1829beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1830beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv,
1831beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                (M4NO_ERROR != result), result);
1832beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            if (needToBeLoaded == false) {
1833beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                goto videoEditor_populateSettings_cleanup;
1834beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            }
1835beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1836cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            regenerateAudio = false;
1837cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pEnv->SetBooleanField(thiz,fid,regenerateAudio);
1838cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
1839cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1840cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        /* Audio mix and duck */
1841cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        fid = pEnv->GetFieldID(audioSettingClazz,"ducking_threshold","I");
1842cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->uiInDucking_threshold
1843cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            = pEnv->GetIntField(audioSettingObject,fid);
1844beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1845cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_TRACE1_1("ducking threshold = %d",
1846cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiInDucking_threshold);
1847cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1848cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        fid = pEnv->GetFieldID(audioSettingClazz,"ducking_lowVolume","I");
1849cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->uiInDucking_lowVolume
1850cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            = pEnv->GetIntField(audioSettingObject,fid);
1851beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1852cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_TRACE1_1("ducking lowVolume = %d",
1853cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiInDucking_lowVolume);
1854cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1855cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        fid = pEnv->GetFieldID(audioSettingClazz,"bInDucking_enable","Z");
1856cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->mAudioSettings->bInDucking_enable
1857cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            = pEnv->GetBooleanField(audioSettingObject,fid);
1858cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_TRACE1_1("ducking lowVolume = %d",
1859cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->bInDucking_enable);
1860beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1861cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    } else {
1862cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (pContext->mAudioSettings != M4OSA_NULL) {
1863cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->pFile = M4OSA_NULL;
1864cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->bRemoveOriginal = 0;
1865cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiNbChannels = 0;
1866cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiSamplingFrequency = 0;
1867cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiExtendedSamplingFrequency = 0;
1868cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiAddCts = 0;
1869cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiAddVolume = 0;
1870cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->beginCutMs = 0;
1871cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->endCutMs = 0;
1872cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi               pContext->mAudioSettings->fileType = 0;
1873cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->bLoop = 0;
1874cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiInDucking_lowVolume  = 0;
1875cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->bInDucking_enable  = 0;
1876cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiBTChannelCount  = 0;
1877cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiInDucking_threshold = 0;
1878cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1879cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            fid = pEnv->GetFieldID(engineClass,"mRegenerateAudio","Z");
1880cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            bool regenerateAudio = pEnv->GetBooleanField(thiz,fid);
1881beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            if (!regenerateAudio) {
1882cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                regenerateAudio = true;
1883cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                pEnv->SetBooleanField(thiz,fid,regenerateAudio);
1884cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            }
1885cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
1886cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
1887beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1888beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    if (pContext->pEditSettings != NULL)
1889cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
1890cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        result = pContext->mPreviewController->loadEditSettings(pContext->pEditSettings,
1891beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            pContext->mAudioSettings);
1892cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv,
1893cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                            (M4NO_ERROR != result), result);
1894cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1895beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        if (needToBeLoaded) {
1896beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            pContext->mPreviewController->setJniCallback((void*)pContext,
1897beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            (jni_progress_callback_fct)jniPreviewProgressCallback);
1898beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        }
1899beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi    }
1900cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1901beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray KundargivideoEditor_populateSettings_cleanup:
1902cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        j = 0;
1903cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        while (j < nbOverlays)
1904cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
1905cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            if (pContext->pEditSettings->Effects[pOverlayIndex[j]].xVSS.pFramingBuffer->pac_data != \
1906cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_NULL) {
1907cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_free((M4OSA_MemAddr32)pContext->pEditSettings->\
1908cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                Effects[pOverlayIndex[j]].xVSS.pFramingBuffer->pac_data);
1909cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                pContext->pEditSettings->\
1910cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                Effects[pOverlayIndex[j]].xVSS.pFramingBuffer->pac_data = M4OSA_NULL;
1911cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            }
1912cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            j++;
1913cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
1914beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1915beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        j = 0;
1916beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        while (j < pContext->pEditSettings->nbEffects)
1917beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        {
1918beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            if (pContext->pEditSettings->Effects[j].xVSS.pFramingFilePath != M4OSA_NULL) {
1919beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                if (pContext->pEditSettings->Effects[j].xVSS.pFramingBuffer != M4OSA_NULL) {
1920beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                    M4OSA_free((M4OSA_MemAddr32)pContext->pEditSettings->\
1921beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                    Effects[j].xVSS.pFramingBuffer);
1922beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                    pContext->pEditSettings->Effects[j].xVSS.pFramingBuffer = M4OSA_NULL;
1923beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi                }
1924beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi            }
1925beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi          j++;
1926beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi        }
1927beb9fc8ee8d3bd14d141104e91d41809dcfe0e1aDharmaray Kundargi
1928cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pOverlayIndex != M4OSA_NULL)
1929cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
1930cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_free((M4OSA_MemAddr32)pOverlayIndex);
1931cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pOverlayIndex = M4OSA_NULL;
1932cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
1933cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return;
1934cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
1935cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1936cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void
1937cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_startPreview(
1938cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                 pEnv,
1939cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                 thiz,
1940cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                 mSurface,
1941cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jlong                   fromMs,
1942cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jlong                   toMs,
1943cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jint                    callbackInterval,
1944cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jboolean                loop)
1945cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
1946cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool needToBeLoaded = true;
1947cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR result = M4NO_ERROR;
1948cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", "videoEditor_startPreview()");
1949cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1950cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditContext* pContext = M4OSA_NULL;
1951cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Get the context.
1952cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext = (ManualEditContext*)videoEditClasses_getContext(&needToBeLoaded, pEnv, thiz);
1953cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1954cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Make sure that the context was set.
1955cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1956cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == pContext),
1957cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
1958cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1959cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1960cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     (M4OSA_NULL == pContext->mAudioSettings),
1961cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     "not initialized");
1962cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Make sure that the context was set.
1963cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1964cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 (M4OSA_NULL == pContext->mPreviewController),
1965cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 "not initialized");
1966cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1967cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Validate the mSurface parameter.
1968cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalArgumentException(&needToBeLoaded, pEnv,
1969cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                (NULL == mSurface),
1970cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                "mSurface is null");
1971cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1972cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jclass surfaceClass = pEnv->FindClass("android/view/Surface");
1973cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1974cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == surfaceClass),
1975cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
1976cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    //jfieldID surface_native = pEnv->GetFieldID(surfaceClass, "mSurface", "I");
1977cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jfieldID surface_native
1978cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        = pEnv->GetFieldID(surfaceClass, ANDROID_VIEW_SURFACE_JNI_ID, "I");
1979cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1980cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
1981cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == surface_native),
1982cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
1983cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1984cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    Surface* const p = (Surface*)pEnv->GetIntField(mSurface, surface_native);
1985cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1986cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    sp<Surface> previewSurface = sp<Surface>(p);
1987cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1988cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    result =  pContext->mPreviewController->setSurface(previewSurface);
1989cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv,
1990cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4NO_ERROR != result), result);
1991cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", "fromMs=%ld, toMs=%ld",
1992cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4OSA_UInt32)fromMs, (M4OSA_Int32)toMs);
1993cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
1994cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    result = pContext->mPreviewController->startPreview((M4OSA_UInt32)fromMs,
1995cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                (M4OSA_Int32)toMs,
1996cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                (M4OSA_UInt16)callbackInterval,
1997cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                (M4OSA_Bool)loop);
1998cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowRuntimeException(&needToBeLoaded, pEnv, (M4NO_ERROR != result), result);
1999cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
2000cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2001cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2002cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic jobject
2003cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_getProperties(
2004cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
2005cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             thiz,
2006cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jstring                             file)
2007cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
2008cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jobject object = M4OSA_NULL;
2009cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    object = videoEditProp_getProperties(pEnv,thiz,file);
2010cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2011cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return object;
2012cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2013cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
2014cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic int videoEditor_getPixels(
2015cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    JNIEnv*                     env,
2016cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    jobject                     thiz,
2017cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    jstring                     path,
2018cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    jintArray                   pixelArray,
2019cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    M4OSA_UInt32                width,
2020cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    M4OSA_UInt32                height,
2021cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    M4OSA_UInt32                timeMS)
2022cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
2023cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2024cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR       err = M4NO_ERROR;
2025cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Context   mContext = M4OSA_NULL;
2026cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jint*           m_dst32 = M4OSA_NULL;
2027cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2028cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2029cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Add a text marker (the condition must always be true).
2030cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ADD_TEXT_MARKER_FUN(NULL != env)
2031cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2032cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    const char *pString = env->GetStringUTFChars(path, NULL);
2033cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pString == M4OSA_NULL) {
2034cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (env != NULL) {
2035cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            jniThrowException(env, "java/lang/RuntimeException", "Input string null");
2036cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2037cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        return M4ERR_ALLOC;
2038cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2039cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2040cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    err = ThumbnailOpen(&mContext,(const M4OSA_Char*)pString, M4OSA_FALSE);
2041cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (err != M4NO_ERROR || mContext == M4OSA_NULL) {
2042cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (pString != NULL) {
2043cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            env->ReleaseStringUTFChars(path, pString);
2044cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2045cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (env != NULL) {
2046cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            jniThrowException(env, "java/lang/RuntimeException", "ThumbnailOpen failed");
2047cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2048cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2049cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2050cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    m_dst32 = env->GetIntArrayElements(pixelArray, NULL);
2051cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2052cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    err = ThumbnailGetPixels32(mContext, (M4OSA_Int32 *)m_dst32, width,height,&timeMS);
2053cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (err != M4NO_ERROR ) {
2054cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (env != NULL) {
2055cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            jniThrowException(env, "java/lang/RuntimeException",\
2056cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                "ThumbnailGetPixels32 failed");
2057cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2058cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2059cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    env->ReleaseIntArrayElements(pixelArray, m_dst32, 0);
2060cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2061cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ThumbnailClose(mContext);
2062cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pString != NULL) {
2063cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        env->ReleaseStringUTFChars(path, pString);
2064cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2065cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2066cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return timeMS;
2067cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
2068cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2069cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic int videoEditor_getPixelsList(
2070cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                     env,
2071cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                     thiz,
2072cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jstring                     path,
2073cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jintArray                 pixelArray,
2074cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_UInt32             width,
2075cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_UInt32             height,
2076cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_UInt32             deltatimeMS,
2077cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_UInt32            noOfThumbnails,
2078cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_UInt32                startTime,
2079cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_UInt32                endTime)
2080cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
2081cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2082cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR           err;
2083cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Context       mContext = M4OSA_NULL;
2084cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jint*               m_dst32;
2085cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32        timeMS = startTime;
2086cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    int                 arrayOffset = 0;
2087cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2088cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2089cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2090cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Add a text marker (the condition must always be true).
2091cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ADD_TEXT_MARKER_FUN(NULL != env)
2092cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2093cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    const char *pString = env->GetStringUTFChars(path, NULL);
2094cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pString == M4OSA_NULL) {
2095cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (env != NULL) {
2096cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            jniThrowException(env, "java/lang/RuntimeException", "Input string null");
2097cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2098cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        return M4ERR_ALLOC;
2099cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2100cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2101cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    err = ThumbnailOpen(&mContext,(const M4OSA_Char*)pString, M4OSA_FALSE);
2102cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (err != M4NO_ERROR || mContext == M4OSA_NULL) {
2103cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (env != NULL) {
2104cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            jniThrowException(env, "java/lang/RuntimeException", "ThumbnailOpen failed");
2105cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2106cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (pString != NULL) {
2107cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            env->ReleaseStringUTFChars(path, pString);
2108cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2109cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        return err;
2110cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2111cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2112cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    m_dst32 = env->GetIntArrayElements(pixelArray, NULL);
2113cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2114cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    do {
2115cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        err = ThumbnailGetPixels32(mContext, ((M4OSA_Int32 *)m_dst32 + arrayOffset),
2116cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            width,height,&timeMS);
2117cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (err != M4NO_ERROR ) {
2118cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            if (env != NULL) {
2119cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jniThrowException(env, "java/lang/RuntimeException",\
2120cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    "ThumbnailGetPixels32 failed");
2121cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            }
2122cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            return err;
2123cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2124cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        timeMS += deltatimeMS;
2125cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        arrayOffset += (width * height * 4);
2126cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        noOfThumbnails--;
2127cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    } while(noOfThumbnails > 0);
2128cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2129cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    env->ReleaseIntArrayElements(pixelArray, m_dst32, 0);
2130cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2131cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ThumbnailClose(mContext);
2132cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pString != NULL) {
2133cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        env->ReleaseStringUTFChars(path, pString);
2134cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2135cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2136cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return err;
2137cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2138cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
2139cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2140cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic M4OSA_ERR
2141cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_toUTF8Fct(
2142cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_Void*                         pBufferIn,
2143cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_UInt8*                        pBufferOut,
2144cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_UInt32*                       bufferOutSize)
2145cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
2146cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR    result = M4NO_ERROR;
2147cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32 length = 0;
2148cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2149cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", "videoEditor_toUTF8Fct()");
2150cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2151cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Determine the length of the input buffer.
2152cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (M4OSA_NULL != pBufferIn)
2153cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
2154cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        length = M4OSA_chrLength((M4OSA_Char *)pBufferIn);
2155cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2156cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2157cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Check if the output buffer is large enough to hold the input buffer.
2158cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if ((*bufferOutSize) > length)
2159cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
2160cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if the input buffer is not M4OSA_NULL.
2161cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (M4OSA_NULL != pBufferIn)
2162cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2163cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Copy the temp path, ignore the result.
2164cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_chrNCopy((M4OSA_Char *)pBufferOut, (M4OSA_Char *)pBufferIn, length);
2165cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2166cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        else
2167cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2168cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Set the output buffer to an empty string.
2169cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            (*(M4OSA_Char *)pBufferOut) = 0;
2170cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2171cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2172cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else
2173cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
2174cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // The buffer is too small.
2175cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        result = M4xVSSWAR_BUFFER_OUT_TOO_SMALL;
2176cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2177cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2178cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Return the buffer output size.
2179cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    (*bufferOutSize) = length + 1;
2180cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2181cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Return the result.
2182cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return(result);
2183cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
2184cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2185cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic M4OSA_ERR
2186cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_fromUTF8Fct(
2187cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_UInt8*                        pBufferIn,
2188cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_Void*                         pBufferOut,
2189cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_UInt32*                       bufferOutSize)
2190cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
2191cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR    result = M4NO_ERROR;
2192cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32 length = 0;
2193cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2194cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", "videoEditor_fromUTF8Fct()");
2195cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2196cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Determine the length of the input buffer.
2197cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (M4OSA_NULL != pBufferIn)
2198cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
2199cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        length = M4OSA_chrLength((M4OSA_Char *)pBufferIn);
2200cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2201cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2202cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Check if the output buffer is large enough to hold the input buffer.
2203cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if ((*bufferOutSize) > length)
2204cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
2205cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if the input buffer is not M4OSA_NULL.
2206cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (M4OSA_NULL != pBufferIn)
2207cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2208cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Copy the temp path, ignore the result.
2209cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_chrNCopy((M4OSA_Char *)pBufferOut, (M4OSA_Char *)pBufferIn, length);
2210cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2211cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        else
2212cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2213cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Set the output buffer to an empty string.
2214cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            (*(M4OSA_Char *)pBufferOut) = 0;
2215cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2216cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2217cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else
2218cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
2219cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // The buffer is too small.
2220cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        result = M4xVSSWAR_BUFFER_OUT_TOO_SMALL;
2221cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2222cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2223cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Return the buffer output size.
2224cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    (*bufferOutSize) = length + 1;
2225cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2226cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Return the result.
2227cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return(result);
2228cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
2229cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2230cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic M4OSA_ERR
2231cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_getTextRgbBufferFct(
2232cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_Void*                         pRenderingData,
2233cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_Void*                         pTextBuffer,
2234cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4OSA_UInt32                        textBufferSize,
2235cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                M4VIFI_ImagePlane**                 pOutputPlane)
2236cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
2237cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR result = M4NO_ERROR;
2238cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2239cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", "videoEditor_getTextRgbBufferFct()");
2240cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2241cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Return the result.
2242cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return(result);
2243cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
2244cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2245cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void
2246cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_callOnProgressUpdate(
2247cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                ManualEditContext*                  pContext,
2248cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                int                                 task,
2249cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                int                                 progress)
2250cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
2251cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    JNIEnv* pEnv = NULL;
2252cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2253cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2254cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Attach the current thread.
2255cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext->pVM->AttachCurrentThread(&pEnv, NULL);
2256cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2257cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2258cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Call the on completion callback.
2259cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pEnv->CallVoidMethod(pContext->engine, pContext->onProgressUpdateMethodId,
2260cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi     videoEditJava_getEngineCToJava(task), progress);
2261cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2262cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2263cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Detach the current thread.
2264cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext->pVM->DetachCurrentThread();
2265cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
2266cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2267cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void
2268cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_freeContext(
2269cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
2270cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                ManualEditContext**                 ppContext)
2271cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
2272cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditContext* pContext = M4OSA_NULL;
2273cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2274cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", "videoEditor_freeContext");
2275cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2276cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the context pointer.
2277cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext = (*ppContext);
2278cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2279cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Check if the context was set.
2280cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (M4OSA_NULL != pContext)
2281cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
2282cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if a global reference to the engine object was set.
2283cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (NULL != pContext->engine)
2284cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2285cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Free the global reference.
2286cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pEnv->DeleteGlobalRef(pContext->engine);
2287cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->engine = NULL;
2288cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2289cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2290cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if the temp path was set.
2291cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (M4OSA_NULL != pContext->initParams.pTempPath)
2292cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2293cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Free the memory allocated for the temp path.
2294cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            videoEditOsal_free(pContext->initParams.pTempPath);
2295cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->initParams.pTempPath = M4OSA_NULL;
2296cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2297cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2298cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if the file writer was set.
2299cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (M4OSA_NULL != pContext->initParams.pFileWritePtr)
2300cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2301cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Free the memory allocated for the file writer.
2302cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            videoEditOsal_free(pContext->initParams.pFileWritePtr);
2303cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->initParams.pFileWritePtr = M4OSA_NULL;
2304cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2305cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2306cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if the file reader was set.
2307cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (M4OSA_NULL != pContext->initParams.pFileReadPtr)
2308cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2309cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Free the memory allocated for the file reader.
2310cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            videoEditOsal_free(pContext->initParams.pFileReadPtr);
2311cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->initParams.pFileReadPtr = M4OSA_NULL;
2312cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2313cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2314cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Free the memory allocated for the context.
2315cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        videoEditOsal_free(pContext);
2316cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext = M4OSA_NULL;
2317cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2318cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Reset the context pointer.
2319cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (*ppContext) = M4OSA_NULL;
2320cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2321cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
2322cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2323cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic jobject
2324cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_getVersion(
2325cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
2326cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             thiz)
2327cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
2328cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool           isSuccessful          = true;
2329cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jobject        version         = NULL;
2330cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4_VersionInfo versionInfo     = {0, 0, 0, 0};
2331cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR      result          = M4NO_ERROR;
2332cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2333cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR", "videoEditor_getVersion()");
2334cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2335cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    versionInfo.m_structSize = sizeof(versionInfo);
2336cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    versionInfo.m_major = VIDEOEDITOR_VERSION_MAJOR;
2337cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    versionInfo.m_minor = VIDEOEDITOR_VERSION_MINOR;
2338cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    versionInfo.m_revision = VIDEOEDITOR_VERSION_REVISION;
2339cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2340cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR", "videoEditor_getVersion() major %d,\
2341cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi     minor %d, revision %d", versionInfo.m_major, versionInfo.m_minor, versionInfo.m_revision);
2342cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2343cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Create a version object.
2344cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditClasses_createVersion(&isSuccessful, pEnv, &versionInfo, &version);
2345cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2346cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Return the version object.
2347cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return(version);
2348cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
2349cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2350cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void
2351cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_init(
2352cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
2353cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             thiz,
2354cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jstring                             tempPath,
2355cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jstring                             libraryPath)
2356cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
2357cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool                  initialized            = true;
2358cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditContext*    pContext               = M4OSA_NULL;
2359cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VideoEditJava_EngineMethodIds methodIds              = {NULL};
2360cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Char*           pLibraryPath           = M4OSA_NULL;
2361cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Char*           pTextRendererPath      = M4OSA_NULL;
2362cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32          textRendererPathLength = 0;
2363cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR             result                 = M4NO_ERROR;
2364cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2365cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR", "videoEditor_init()");
2366cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2367cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Add a text marker (the condition must always be true).
2368cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ADD_TEXT_MARKER_FUN(NULL != pEnv)
2369cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2370cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Get the context.
2371cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext = (ManualEditContext*)videoEditClasses_getContext(&initialized, pEnv, thiz);
2372cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2373cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Get the engine method ids.
2374cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_getEngineMethodIds(&initialized, pEnv, &methodIds);
2375cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2376cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Validate the tempPath parameter.
2377cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalArgumentException(&initialized, pEnv,
2378cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                (NULL == tempPath),
2379cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                "tempPath is null");
2380cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2381cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Make sure that the context was not set already.
2382cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&initialized, pEnv,
2383cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL != pContext),
2384cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "already initialized");
2385cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2386cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Check if the initialization succeeded (required because of dereferencing of psContext,
2387cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // and freeing when initialization fails).
2388cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (initialized)
2389cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
2390cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Allocate a new context.
2391cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext = new ManualEditContext;
2392cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2393cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if the initialization succeeded (required because of dereferencing of psContext).
2394cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        //if (initialized)
2395cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (pContext != NULL)
2396cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2397cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Set the state to not initialized.
2398cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->state = ManualEditState_NOT_INITIALIZED;
2399cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2400cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Allocate a file read pointer structure.
2401cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->initParams.pFileReadPtr =
2402cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi             (M4OSA_FileReadPointer*)videoEditOsal_alloc(&initialized, pEnv,
2403cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi              sizeof(M4OSA_FileReadPointer), "FileReadPointer");
2404cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2405cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Allocate a file write pointer structure.
2406cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->initParams.pFileWritePtr =
2407cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi             (M4OSA_FileWriterPointer*)videoEditOsal_alloc(&initialized, pEnv,
2408cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi              sizeof(M4OSA_FileWriterPointer), "FileWriterPointer");
2409cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2410cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Get the temp path.
2411cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_Char* tmpString =
2412cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                (M4OSA_Char *)videoEditJava_getString(&initialized, pEnv, tempPath,
2413cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                NULL, M4OSA_NULL);
2414cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->initParams.pTempPath = (M4OSA_Char *)
2415cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                 M4OSA_malloc(M4OSA_chrLength(tmpString) + 1, 0x0,
2416cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                 (M4OSA_Char *)"tempPath");
2417cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            //initialize the first char. so that strcat works.
2418cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_Char *ptmpChar = (M4OSA_Char*)pContext->initParams.pTempPath;
2419cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            ptmpChar[0] = 0x00;
2420cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_chrNCat((M4OSA_Char*)pContext->initParams.pTempPath, tmpString, M4OSA_chrLength(tmpString));
2421cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_chrNCat((M4OSA_Char*)pContext->initParams.pTempPath, (M4OSA_Char*)"/", 1);
2422cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_free((M4OSA_MemAddr32)tmpString);
2423c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            pContext->mIsUpdateOverlay = false;
2424c16ccc1c5a6293136ae9bd4756dc2f57914a2020Dharmaray Kundargi            pContext->mOverlayFileName = NULL;
2425cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2426cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2427cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if the initialization succeeded
2428cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // (required because of dereferencing of pContext, pFileReadPtr and pFileWritePtr).
2429cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (initialized)
2430cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2431cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2432cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Initialize the OSAL file system function pointers.
2433cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            videoEditOsal_getFilePointers(pContext->initParams.pFileReadPtr ,
2434cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                          pContext->initParams.pFileWritePtr);
2435cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2436cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Set the UTF8 conversion functions.
2437cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->initParams.pConvToUTF8Fct   = videoEditor_toUTF8Fct;
2438cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->initParams.pConvFromUTF8Fct = videoEditor_fromUTF8Fct;
2439cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2440cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Set the callback method ids.
2441cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->onProgressUpdateMethodId = methodIds.onProgressUpdate;
2442cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2443cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Set the virtual machine.
2444cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pEnv->GetJavaVM(&(pContext->pVM));
2445cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2446cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Create a global reference to the engine object.
2447cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->engine = pEnv->NewGlobalRef(thiz);
2448cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2449cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Check if the global reference could be created.
2450cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            videoEditJava_checkAndThrowRuntimeException(&initialized, pEnv,
2451cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi             (NULL == pContext->engine), M4NO_ERROR);
2452cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2453cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2454cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if the initialization succeeded (required because of dereferencing of pContext).
2455cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (initialized)
2456cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2457cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Log the API call.
2458cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR", "M4xVSS_Init()");
2459cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2460cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Initialize the visual studio library.
2461cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            result = M4xVSS_Init(&pContext->engineContext, &pContext->initParams);
2462cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2463cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Log the result.
2464cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            VIDEOEDIT_LOG_RESULT(ANDROID_LOG_INFO, "VIDEO_EDITOR",
2465cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi             videoEditOsal_getResultString(result));
2466cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2467cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Check if the library could be initialized.
2468cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            videoEditJava_checkAndThrowRuntimeException(&initialized, pEnv,
2469cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi             (M4NO_ERROR != result), result);
2470cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2471cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2472cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if(initialized)
2473cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2474cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mPreviewController = new VideoEditorPreviewController();
2475cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            videoEditJava_checkAndThrowIllegalStateException(&initialized, pEnv,
2476cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 (M4OSA_NULL == pContext->mPreviewController),
2477cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 "not initialized");
2478cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings =
2479cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi             (M4xVSS_AudioMixingSettings *)
2480cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi             M4OSA_malloc(sizeof(M4xVSS_AudioMixingSettings),0x0,
2481cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi             (M4OSA_Char *)"mAudioSettings");
2482cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            videoEditJava_checkAndThrowIllegalStateException(&initialized, pEnv,
2483cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     (M4OSA_NULL == pContext->mAudioSettings),
2484cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                     "not initialized");
2485cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->pFile = M4OSA_NULL;
2486cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->bRemoveOriginal = 0;
2487cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiNbChannels = 0;
2488cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiSamplingFrequency = 0;
2489cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiExtendedSamplingFrequency = 0;
2490cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiAddCts = 0;
2491cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiAddVolume = 0;
2492cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->beginCutMs = 0;
2493cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->endCutMs = 0;
2494cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->fileType = 0;
2495cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->bLoop = 0;
2496cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiInDucking_lowVolume  = 0;
2497cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->bInDucking_enable  = 0;
2498cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiBTChannelCount  = 0;
2499cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings->uiInDucking_threshold = 0;
2500cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2501cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if the library could be initialized.
2502cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (initialized)
2503cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2504cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Set the state to initialized.
2505cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->state = ManualEditState_INITIALIZED;
2506cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2507cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2508cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Set the context.
2509cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        videoEditClasses_setContext(&initialized, pEnv, thiz, (void* )pContext);
2510cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pLibraryPath = M4OSA_NULL;
2511cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2512cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->pEditSettings = M4OSA_NULL;
2513cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Cleanup if anything went wrong during initialization.
2514cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (!initialized)
2515cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2516cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Free the context.
2517cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            videoEditor_freeContext(pEnv, &pContext);
2518cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2519cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2520cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
2521cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2522cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi/*+ PROGRESS CB */
2523cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic
2524cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargiM4OSA_ERR videoEditor_processClip(
2525cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                            JNIEnv*  pEnv,
2526cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                            jobject  thiz,
2527cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                            int      unuseditemID) {
2528cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2529cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool               loaded           = true;
2530cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditContext* pContext         = NULL;
2531cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt8        progress         = 0;
2532cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt8        progressBase     = 0;
2533cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt8        lastProgress     = 0;
2534cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR          result           = M4NO_ERROR;
2535cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2536cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Get the context.
2537cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext = (ManualEditContext*)videoEditClasses_getContext(&loaded, pEnv, thiz);
2538cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2539cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Make sure that the context was set.
2540cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&loaded, pEnv,
2541cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == pContext),
2542cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
2543cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2544cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // We start in Analyzing state
25455618e037af1a9d4323990a580d4181b9bc8e3091Dheeraj Sharma    pContext->state = ManualEditState_INITIALIZED;
2546cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR          completionResult = M4VSS3GPP_WAR_ANALYZING_DONE;
2547cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditState    completionState  = ManualEditState_OPENED;
2548cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditState    errorState       = ManualEditState_ANALYZING_ERROR;
2549cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2550cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // While analyzing progress goes from 0 to 50
2551cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    progressBase     = 0;
2552cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2553cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Set the text rendering function.
2554cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (M4OSA_NULL != pContext->pTextRendererFunction)
2555cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
2556cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Use the text renderer function in the library.
2557cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->pEditSettings->xVSS.pTextRenderingFct = pContext->pTextRendererFunction;
2558cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2559cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else
2560cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
2561cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Use the internal text renderer function.
2562cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->pEditSettings->xVSS.pTextRenderingFct = videoEditor_getTextRgbBufferFct;
2563cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2564cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2565cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Send the command.
2566cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    LOGV("videoEditor_processClip ITEM %d Calling M4xVSS_SendCommand()", unuseditemID);
2567cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    result = M4xVSS_SendCommand(pContext->engineContext, pContext->pEditSettings);
2568cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    LOGV("videoEditor_processClip ITEM %d M4xVSS_SendCommand() returned 0x%x",
2569cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        unuseditemID, (unsigned int) result);
2570cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2571cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Remove warnings indications (we only care about errors here)
2572cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if ((result == M4VSS3GPP_WAR_TRANSCODING_NECESSARY)
2573cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        || (result == M4VSS3GPP_WAR_OUTPUTFILESIZE_EXCEED)) {
2574cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        result = M4NO_ERROR;
2575cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2576cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2577cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Send the first progress indication (=0)
2578cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    LOGV("VERY FIRST PROGRESS videoEditor_processClip ITEM %d Progress indication %d",
2579cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        unuseditemID, progress);
2580cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pEnv->CallVoidMethod(pContext->engine, pContext->onProgressUpdateMethodId,
2581cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        unuseditemID, progress);
2582cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2583cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Check if a task is being performed.
2584cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // ??? ADD STOPPING MECHANISM
2585cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    LOGV("videoEditor_processClip Entering processing loop");
2586cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    while((result == M4NO_ERROR)
2587cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        &&(pContext->state!=ManualEditState_SAVED)
2588cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        &&(pContext->state!=ManualEditState_STOPPING)) {
2589cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2590cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Perform the next processing step.
2591cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            //LOGV("LVME_processClip Entering M4xVSS_Step()");
2592cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            result = M4xVSS_Step(pContext->engineContext, &progress);
2593cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            //LOGV("LVME_processClip M4xVSS_Step() returned 0x%x", (unsigned int)result);
2594cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2595cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Log the the 1 % .. 100 % progress after processing.
2596cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            progress = progressBase + progress/2;
2597cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            if (progress != lastProgress)
2598cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            {
2599cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                // Send a progress notification.
2600cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                LOGV("videoEditor_processClip ITEM %d Progress indication %d",
2601cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    unuseditemID, progress);
2602cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                pEnv->CallVoidMethod(pContext->engine,
2603cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    pContext->onProgressUpdateMethodId,
2604cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    unuseditemID, progress);
2605cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                lastProgress = progress;
2606cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            }
2607cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2608cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Check if processing has been completed.
2609cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            if (result == completionResult)
2610cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            {
2611cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                // Set the state to the completions state.
2612cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                pContext->state = completionState;
2613cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                LOGV("videoEditor_processClip ITEM %d STATE changed to %d",
2614cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    unuseditemID, pContext->state);
2615cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2616cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                // Reset progress indication, as we switch to next state
2617cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                lastProgress = 0;
2618cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2619cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                // Reset error code, as we start a new round of processing
2620cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                result = M4NO_ERROR;
2621cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2622cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                // Check if we are analyzing input
2623cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                if (pContext->state == ManualEditState_OPENED) {
2624cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    // File is opened, we must start saving it
2625cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    LOGV("videoEditor_processClip Calling M4xVSS_SaveStart()");
2626cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    result = M4xVSS_SaveStart(pContext->engineContext,
2627cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                        (M4OSA_Char*)pContext->pEditSettings->pOutputFile,
2628cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                        (M4OSA_UInt32)pContext->pEditSettings->uiOutputPathSize);
2629cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    LOGV("videoEditor_processClip ITEM %d SaveStart() returned 0x%x",
2630cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                        unuseditemID, (unsigned int) result);
2631cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2632cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    // Set the state to saving.
2633cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    pContext->state  = ManualEditState_SAVING;
2634cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    completionState  = ManualEditState_SAVED;
2635cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    completionResult = M4VSS3GPP_WAR_SAVING_DONE;
2636cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    errorState       = ManualEditState_SAVING_ERROR;
2637cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2638cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    // While saving progress goes from 50 to 100
2639cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    progressBase     = 50;
2640cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                }
2641cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                // Check if we encoding is ongoing
2642cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                else if (pContext->state == ManualEditState_SAVED) {
2643cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    if (progress != 100) {
2644cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                        // Send a progress notification.
2645cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                        progress = 100;
2646cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                        LOGI("videoEditor_processClip ITEM %d Last progress indication %d",
2647cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                            unuseditemID, progress);
2648cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                        pEnv->CallVoidMethod(pContext->engine,
2649cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                            pContext->onProgressUpdateMethodId,
2650cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                            unuseditemID, progress);
2651cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    }
2652cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2653cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    // Stop the encoding.
2654cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    LOGV("videoEditor_processClip Calling M4xVSS_SaveStop()");
2655cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    result = M4xVSS_SaveStop(pContext->engineContext);
2656cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    LOGV("videoEditor_processClip M4xVSS_SaveStop() returned 0x%x", result);
2657cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                }
2658cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                // Other states are unexpected
2659cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                else {
2660cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    result = M4ERR_STATE;
2661cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    LOGE("videoEditor_processClip ITEM %d State ERROR 0x%x",
2662cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                        unuseditemID, (unsigned int) result);
2663cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                }
2664cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            }
2665cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2666cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Check if an error occurred.
2667cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            if (result != M4NO_ERROR)
2668cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            {
2669cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                // Set the state to the error state.
2670cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                pContext->state = errorState;
2671cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2672cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                // Log the result.
2673cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                LOGE("videoEditor_processClip ITEM %d Processing ERROR 0x%x",
2674cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    unuseditemID, (unsigned int) result);
2675cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            }
2676cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2677cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2678cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Return the error result
2679cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    LOGE("videoEditor_processClip ITEM %d END 0x%x", unuseditemID, (unsigned int) result);
2680cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return result;
2681cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
2682cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi/*+ PROGRESS CB */
2683cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2684cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic int
2685cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_generateClip(
2686cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
2687cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             thiz,
2688cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             settings) {
2689cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool               loaded   = true;
2690cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditContext* pContext = M4OSA_NULL;
2691cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR          result   = M4NO_ERROR;
2692cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2693cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    LOGV("videoEditor_generateClip START");
2694cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2695cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Get the context.
2696cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext = (ManualEditContext*)videoEditClasses_getContext(&loaded, pEnv, thiz);
2697cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2698cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    Mutex::Autolock autoLock(pContext->mLock);
2699cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2700cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Validate the settings parameter.
2701cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalArgumentException(&loaded, pEnv,
2702cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                (NULL == settings),
2703cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                "settings is null");
2704cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2705cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Make sure that the context was set.
2706cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&loaded, pEnv,
2707cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == pContext),
2708cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
2709cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2710cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Load the clip settings
2711cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    LOGV("videoEditor_generateClip Calling videoEditor_loadSettings");
2712cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditor_loadSettings(pEnv, thiz, settings);
2713cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    LOGV("videoEditor_generateClip videoEditor_loadSettings returned");
2714cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2715cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Generate the clip
2716cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    LOGV("videoEditor_generateClip Calling LVME_processClip");
2717cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    result = videoEditor_processClip(pEnv, thiz, 0 /*item id is unused*/);
2718cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    LOGV("videoEditor_generateClip videoEditor_processClip returned 0x%x", result);
2719cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
27205618e037af1a9d4323990a580d4181b9bc8e3091Dheeraj Sharma    if (pContext->state != ManualEditState_INITIALIZED) {
27215618e037af1a9d4323990a580d4181b9bc8e3091Dheeraj Sharma        // Free up memory (whatever the result)
27225618e037af1a9d4323990a580d4181b9bc8e3091Dheeraj Sharma        videoEditor_unloadSettings(pEnv, thiz);
27235618e037af1a9d4323990a580d4181b9bc8e3091Dheeraj Sharma    }
2724cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2725cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    LOGV("videoEditor_generateClip END 0x%x", (unsigned int) result);
2726cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return result;
2727cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
2728cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2729cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void
2730cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_loadSettings(
2731cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
2732cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             thiz,
2733cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             settings)
2734cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
2735cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool               needToBeLoaded   = true;
2736cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditContext* pContext = M4OSA_NULL;
2737cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2738cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR", "videoEditor_loadSettings()");
2739cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2740cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Add a code marker (the condition must always be true).
2741cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ADD_CODE_MARKER_FUN(NULL != pEnv)
2742cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2743cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Get the context.
2744cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext = (ManualEditContext*)videoEditClasses_getContext(&needToBeLoaded,
2745cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                                pEnv, thiz);
2746cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2747cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Validate the settings parameter.
2748cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalArgumentException(&needToBeLoaded, pEnv,
2749cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                (NULL == settings),
2750cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                "settings is null");
2751cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2752cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Make sure that the context was set.
2753cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
2754cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == pContext),
2755cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
2756cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2757cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Check if the context is valid (required because the context is dereferenced).
2758cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (needToBeLoaded)
2759cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
2760cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Make sure that we are in a correct state.
2761cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        videoEditJava_checkAndThrowIllegalStateException(&needToBeLoaded, pEnv,
2762cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                             (pContext->state != ManualEditState_INITIALIZED),
2763cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                             "settings already loaded");
2764cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2765cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Retrieve the edit settings.
2766cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if(pContext->pEditSettings != M4OSA_NULL) {
2767cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            videoEditClasses_freeEditSettings(&pContext->pEditSettings);
2768cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->pEditSettings = M4OSA_NULL;
2769cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2770cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        videoEditClasses_getEditSettings(&needToBeLoaded, pEnv, settings,
2771cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            &pContext->pEditSettings,true);
2772cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2773cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2774cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Check if the edit settings could be retrieved.
2775cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (needToBeLoaded)
2776cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
2777cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Log the edit settings.
2778cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR", "inside load settings");
2779cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        VIDEOEDIT_LOG_EDIT_SETTINGS(pContext->pEditSettings);
2780cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2781cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    LOGV("videoEditor_loadSettings END");
2782cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
2783cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2784cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2785cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2786cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void
2787cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_unloadSettings(
2788cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
2789cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             thiz)
2790cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
2791cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool               needToBeUnLoaded = true;
2792cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditContext* pContext = M4OSA_NULL;
2793cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR          result   = M4NO_ERROR;
2794cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2795cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR", "videoEditor_unloadSettings()");
2796cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2797cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Get the context.
2798cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext = (ManualEditContext*)videoEditClasses_getContext(&needToBeUnLoaded, pEnv, thiz);
2799cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2800cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Make sure that the context was set.
2801cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&needToBeUnLoaded, pEnv,
2802cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == pContext),
2803cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
2804cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2805cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Check if the context is valid (required because the context is dereferenced).
2806cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (needToBeUnLoaded)
2807cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
2808cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        LOGV("videoEditor_unloadSettings state %d", pContext->state);
2809cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Make sure that we are in a correct state.
2810cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        videoEditJava_checkAndThrowIllegalStateException(&needToBeUnLoaded, pEnv,
2811cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                     ((pContext->state != ManualEditState_ANALYZING      ) &&
2812cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                      (pContext->state != ManualEditState_ANALYZING_ERROR) &&
2813cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                      (pContext->state != ManualEditState_OPENED         ) &&
2814cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                      (pContext->state != ManualEditState_SAVING_ERROR   ) &&
2815cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                      (pContext->state != ManualEditState_SAVED          ) &&
2816cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                      (pContext->state != ManualEditState_STOPPING       ) ),
2817cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                     "videoEditor_unloadSettings no load settings in progress");
2818cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2819cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2820cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Check if we are in a correct state.
2821cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (needToBeUnLoaded)
2822cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
2823cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if the thread could be stopped.
2824cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (needToBeUnLoaded)
2825cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2826cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Close the command.
2827cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            LOGV("videoEditor_unloadSettings Calling M4xVSS_CloseCommand()");
2828cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            result = M4xVSS_CloseCommand(pContext->engineContext);
2829cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            LOGV("videoEditor_unloadSettings M4xVSS_CloseCommand() returned 0x%x",
2830cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                (unsigned int)result);
2831cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2832cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Check if the command could be closed.
2833cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            videoEditJava_checkAndThrowRuntimeException(&needToBeUnLoaded, pEnv,
2834cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi             (M4NO_ERROR != result), result);
2835cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2836cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2837cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if the command could be closed.
2838cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (needToBeUnLoaded)
2839cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2840cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Free the edit settings.
2841cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            //videoEditClasses_freeEditSettings(&pContext->pEditSettings);
2842cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2843cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Reset the thread result.
2844cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->threadResult = M4NO_ERROR;
2845cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2846cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Reset the thread progress.
2847cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->threadProgress = 0;
2848cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2849cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Set the state to initialized.
2850cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->state = ManualEditState_INITIALIZED;
2851cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2852cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2853cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
2854cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2855cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void
2856cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_stopEncoding(
2857cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
2858cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             thiz)
2859cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
2860cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool               stopped  = true;
2861cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditContext* pContext = M4OSA_NULL;
2862cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR          result   = M4NO_ERROR;
2863cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2864cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    LOGV("videoEditor_stopEncoding START");
2865cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2866cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Get the context.
2867cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext = (ManualEditContext*)videoEditClasses_getContext(&stopped, pEnv, thiz);
2868cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2869cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Change state and get Lock
2870cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // This will ensure the generateClip function exits
2871cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext->state = ManualEditState_STOPPING;
2872cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    Mutex::Autolock autoLock(pContext->mLock);
2873cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2874cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Make sure that the context was set.
2875cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&stopped, pEnv,
2876cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == pContext),
2877cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
2878cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2879cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (stopped) {
2880cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2881cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if the command should be closed.
2882cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (pContext->state != ManualEditState_INITIALIZED)
2883cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2884cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Close the command.
2885cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            LOGV("videoEditor_stopEncoding Calling M4xVSS_CloseCommand()");
2886cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            result = M4xVSS_CloseCommand(pContext->engineContext);
2887cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            LOGV("videoEditor_stopEncoding M4xVSS_CloseCommand() returned 0x%x",
2888cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                (unsigned int)result);
2889cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2890cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2891cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if the command could be closed.
2892cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        videoEditJava_checkAndThrowRuntimeException(&stopped, pEnv,
2893cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            (M4NO_ERROR != result), result);
2894cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2895cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Free the edit settings.
2896cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        videoEditClasses_freeEditSettings(&pContext->pEditSettings);
2897cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2898cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Set the state to initialized.
2899cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->state = ManualEditState_INITIALIZED;
2900cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2901cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2902cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
2903cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2904cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic void
2905cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_release(
2906cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv,
2907cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                jobject                             thiz)
2908cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
2909cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool               released = true;
2910cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditContext* pContext = M4OSA_NULL;
2911cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR          result   = M4NO_ERROR;
2912cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2913cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR", "videoEditor_release()");
2914cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2915cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Add a text marker (the condition must always be true).
2916cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ADD_TEXT_MARKER_FUN(NULL != pEnv)
2917cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2918cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Get the context.
2919cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext = (ManualEditContext*)videoEditClasses_getContext(&released, pEnv, thiz);
2920cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2921cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // If context is not set, return (we consider release already happened)
2922cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pContext == NULL) {
2923cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        LOGV("videoEditor_release Nothing to do, context is aleady NULL");
2924cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        return;
2925cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2926cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2927cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2928cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Check if the context is valid (required because the context is dereferenced).
2929cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (released)
2930cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
2931cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (pContext->state != ManualEditState_INITIALIZED)
2932cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2933cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Change state and get Lock
2934cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // This will ensure the generateClip function exits if it is running
2935cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->state = ManualEditState_STOPPING;
2936cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            Mutex::Autolock autoLock(pContext->mLock);
2937cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2938cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2939cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Reset the context.
2940cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        videoEditClasses_setContext(&released, pEnv, thiz, (void *)M4OSA_NULL);
2941cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2942cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if the command should be closed.
2943cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (pContext->state != ManualEditState_INITIALIZED)
2944cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2945cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Close the command.
2946cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            LOGV("videoEditor_release Calling M4xVSS_CloseCommand() state =%d",
2947cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                pContext->state);
2948cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            result = M4xVSS_CloseCommand(pContext->engineContext);
2949cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            LOGV("videoEditor_release M4xVSS_CloseCommand() returned 0x%x",
2950cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                (unsigned int)result);
2951cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2952cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Check if the command could be closed.
2953cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            videoEditJava_checkAndThrowRuntimeException(&released, pEnv,
2954cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                (M4NO_ERROR != result), result);
2955cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2956cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2957cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Cleanup the engine.
2958cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        LOGV("videoEditor_release Calling M4xVSS_CleanUp()");
2959cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        result = M4xVSS_CleanUp(pContext->engineContext);
2960cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        LOGV("videoEditor_release M4xVSS_CleanUp() returned 0x%x", (unsigned int)result);
2961cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2962cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Check if the cleanup succeeded.
2963cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        videoEditJava_checkAndThrowRuntimeException(&released, pEnv,
2964cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            (M4NO_ERROR != result), result);
2965cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2966cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Free the edit settings.
2967cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        videoEditClasses_freeEditSettings(&pContext->pEditSettings);
2968cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext->pEditSettings = M4OSA_NULL;
2969cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2970cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2971cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if(pContext->mPreviewController != M4OSA_NULL)
2972cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2973cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            delete pContext->mPreviewController;
2974cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mPreviewController = M4OSA_NULL;
2975cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2976cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2977cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Free the context.
2978cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if(pContext->mAudioSettings != M4OSA_NULL)
2979cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
2980cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_free((M4OSA_MemAddr32)pContext->mAudioSettings);
2981cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pContext->mAudioSettings = M4OSA_NULL;
2982cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
2983cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        videoEditor_freeContext(pEnv, &pContext);
2984cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
2985cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
2986cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2987cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic int
2988cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargivideoEditor_registerManualEditMethods(
2989cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JNIEnv*                             pEnv)
2990cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
2991cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    int result = -1;
2992cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2993cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR",
2994cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi     "videoEditor_registerManualEditMethods()");
2995cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2996cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Look up the engine class
2997cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jclass engineClazz = pEnv->FindClass(MANUAL_EDIT_ENGINE_CLASS_NAME);
2998cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
2999cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Clear any resulting exceptions.
3000cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pEnv->ExceptionClear();
3001cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3002cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Check if the engine class was found.
3003cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (NULL != engineClazz)
3004cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
3005cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Register all the methods.
3006cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (pEnv->RegisterNatives(engineClazz, gManualEditMethods,
3007cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                sizeof(gManualEditMethods) / sizeof(gManualEditMethods[0])) == JNI_OK)
3008cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
3009cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Success.
3010cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            result = 0;
3011cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
3012cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
3013cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3014cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Return the result.
3015cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return(result);
3016cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
3017cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3018cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi/*******Audio Graph*******/
3019cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3020cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic M4OSA_UInt32 getDecibelSound(M4OSA_UInt32 value)
3021cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
3022cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    int dbSound = 1;
3023cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3024cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (value == 0) return 0;
3025cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3026cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (value > 0x4000 && value <= 0x8000) // 32768
3027cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbSound = 90;
3028cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else if (value > 0x2000 && value <= 0x4000) // 16384
3029cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbSound = 84;
3030cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else if (value > 0x1000 && value <= 0x2000) // 8192
3031cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbSound = 78;
3032cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else if (value > 0x0800 && value <= 0x1000) // 4028
3033cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbSound = 72;
3034cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else if (value > 0x0400 && value <= 0x0800) // 2048
3035cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbSound = 66;
3036cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else if (value > 0x0200 && value <= 0x0400) // 1024
3037cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbSound = 60;
3038cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else if (value > 0x0100 && value <= 0x0200) // 512
3039cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbSound = 54;
3040cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else if (value > 0x0080 && value <= 0x0100) // 256
3041cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbSound = 48;
3042cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else if (value > 0x0040 && value <= 0x0080) // 128
3043cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbSound = 42;
3044cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else if (value > 0x0020 && value <= 0x0040) // 64
3045cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbSound = 36;
3046cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else if (value > 0x0010 && value <= 0x0020) // 32
3047cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbSound = 30;
3048cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else if (value > 0x0008 && value <= 0x0010) //16
3049cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbSound = 24;
3050cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else if (value > 0x0007 && value <= 0x0008) //8
3051cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbSound = 24;
3052cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else if (value > 0x0003 && value <= 0x0007) // 4
3053cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbSound = 18;
3054cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else if (value > 0x0001 && value <= 0x0003) //2
3055cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbSound = 12;
3056cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else if (value > 0x000 && value == 0x0001) // 1
3057cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbSound = 6;
3058cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    else
3059cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbSound = 0;
3060cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3061cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return dbSound;
3062cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
3063cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3064cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargitypedef struct
3065cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
3066cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt8      *m_dataAddress;
3067cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32    m_bufferSize;
3068cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi} M4AM_Buffer;
3069cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3070cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3071581cad2221cb367e9e3ef6991c565cd37ced994fJames DongM4OSA_UInt8 logLookUp[256] = {
3072cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi0,120,137,146,154,159,163,167,171,173,176,178,181,182,184,186,188,189,190,192,193,
3073cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi194,195,196,198,199,199,200,201,202,203,204,205,205,206,207,207,208,209,209,210,
3074cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi211,211,212,212,213,213,214,215,215,216,216,216,217,217,218,218,219,219,220,220,
3075cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi220,221,221,222,222,222,223,223,223,224,224,224,225,225,225,226,226,226,227,227,
3076cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi227,228,228,228,229,229,229,229,230,230,230,230,231,231,231,232,232,232,232,233,
3077cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi233,233,233,233,234,234,234,234,235,235,235,235,236,236,236,236,236,237,237,237,
3078cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi237,237,238,238,238,238,238,239,239,239,239,239,240,240,240,240,240,240,241,241,
3079cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi241,241,241,241,242,242,242,242,242,242,243,243,243,243,243,243,244,244,244,244,
3080cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi244,244,245,245,245,245,245,245,245,246,246,246,246,246,246,246,247,247,247,247,
3081cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi247,247,247,247,248,248,248,248,248,248,248,249,249,249,249,249,249,249,249,250,
3082cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi250,250,250,250,250,250,250,250,251,251,251,251,251,251,251,251,252,252,252,252,
3083cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi252,252,252,252,252,253,253,253,253,253,253,253,253,253,253,254,254,254,254,254,
3084cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi254,254,254,254,255,255,255,255,255,255,255,255,255,255,255};
3085cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3086cd196d3727db641e581d4223815367a5ca5d5637Dharmaray KundargiM4OSA_ERR M4MA_generateAudioGraphFile(JNIEnv* pEnv, M4OSA_Char* pInputFileURL,
3087cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                     M4OSA_Char* pOutFileURL,
3088cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                     M4OSA_UInt32 samplesPerValue,
3089cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                     M4OSA_UInt32 channels,
3090cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                     M4OSA_UInt32 frameDuration,
3091cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                     ManualEditContext* pContext)
3092cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
3093cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR           err;
3094cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Context       outFileHandle = M4OSA_NULL;
3095cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Context       inputFileHandle = M4OSA_NULL;
3096cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4AM_Buffer         bufferIn = {0, 0};
3097cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32        peakVolumeDbValue = 0;
3098cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32        samplesCountInBytes= 0 , numBytesToRead = 0, index = 0;
3099cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32        writeCount = 0, samplesCountBigEndian = 0, volumeValuesCount = 0;
3100cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Int32         seekPos = 0;
3101cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32        fileSize = 0;
3102cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32        totalBytesRead = 0;
3103cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_UInt32        prevProgress = 0;
3104cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool                threadStarted = true;
3105cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3106cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    int dbValue = 0;
3107cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_Int16 *ptr16 ;
3108cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3109cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jclass engineClass = pEnv->FindClass(MANUAL_EDIT_ENGINE_CLASS_NAME);
3110cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    videoEditJava_checkAndThrowIllegalStateException(&threadStarted, pEnv,
3111cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             (M4OSA_NULL == engineClass),
3112cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                             "not initialized");
3113cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3114cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* register the call back function pointer */
3115cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext->onAudioGraphProgressUpdateMethodId =
3116cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pEnv->GetMethodID(engineClass, "onAudioGraphExtractProgressUpdate", "(IZ)V");
3117cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3118cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3119cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* ENTER */
3120cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR", "ENTER - M4MA_generateAudioGraphFile");
3121cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR",
3122cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            "Audio Graph samplesPerValue %d channels %d", samplesPerValue, channels);
3123cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3124cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /******************************************************************************
3125cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        OPEN INPUT AND OUTPUT FILES
3126cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    *******************************************************************************/
3127cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    err = M4OSA_fileReadOpen (&inputFileHandle, pInputFileURL, M4OSA_kFileRead);
3128cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (inputFileHandle == M4OSA_NULL) {
3129cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        VIDEOEDIT_LOG_ERROR(ANDROID_LOG_INFO, "VIDEO_EDITOR",
3130581cad2221cb367e9e3ef6991c565cd37ced994fJames Dong            "M4MA_generateAudioGraphFile: Cannot open input file 0x%lx", err);
3131cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        return err;
3132cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
3133cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3134cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* get the file size for progress */
3135cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    err = M4OSA_fileReadGetOption(inputFileHandle, M4OSA_kFileReadGetFileSize,
3136cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                (M4OSA_Void**)&fileSize);
3137cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if ( err != M4NO_ERROR) {
3138cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        //LVMEL_LOG_ERROR("M4MA_generateAudioGraphFile : File write failed \n");
3139cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        jniThrowException(pEnv, "java/lang/IOException", "file size get option failed");
3140cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        //return -1;
3141cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
3142cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3143cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    err = M4OSA_fileWriteOpen (&outFileHandle,(M4OSA_Char*) pOutFileURL,
3144cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_kFileCreate | M4OSA_kFileWrite);
3145cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (outFileHandle == M4OSA_NULL) {
3146cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (inputFileHandle != NULL)
3147cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
3148cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4OSA_fileReadClose(inputFileHandle);
3149cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
3150cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        return err;
3151cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
3152cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3153cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /******************************************************************************
3154cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        PROCESS THE SAMPLES
3155cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    *******************************************************************************/
3156cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    samplesCountInBytes = (samplesPerValue * sizeof(M4OSA_UInt16) * channels);
3157cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3158cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bufferIn.m_dataAddress = (M4OSA_UInt8*)M4OSA_malloc(samplesCountInBytes*sizeof(M4OSA_UInt16), 0,
3159cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    (M4OSA_Char*)"AudioGraph" );
3160cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if ( bufferIn.m_dataAddress != M4OSA_NULL) {
3161cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        bufferIn.m_bufferSize = samplesCountInBytes*sizeof(M4OSA_UInt16);
3162cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    } else {
3163cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        VIDEOEDIT_LOG_ERROR(ANDROID_LOG_INFO, "VIDEO_EDITOR",
3164581cad2221cb367e9e3ef6991c565cd37ced994fJames Dong            "M4MA_generateAudioGraphFile: Malloc failed for bufferIn.m_dataAddress 0x%lx",
3165cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            M4ERR_ALLOC);
3166cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        return M4ERR_ALLOC;
3167cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
3168cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* sample to be converted to BIG endian ; store the frame duration */
3169cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    samplesCountBigEndian = ((frameDuration>>24)&0xff) | // move byte 3 to byte 0
3170cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    ((frameDuration<<8)&0xff0000) | // move byte 1 to byte 2
3171cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    ((frameDuration>>8)&0xff00) | // move byte 2 to byte 1
3172cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    ((frameDuration<<24)&0xff000000); // byte 0 to byte 3
3173cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3174cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* write the samples per value supplied to out file */
3175cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    err = M4OSA_fileWriteData (outFileHandle, (M4OSA_MemAddr8)&samplesCountBigEndian,
3176cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        sizeof(M4OSA_UInt32) );
3177cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (err != M4NO_ERROR) {
3178cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        jniThrowException(pEnv, "java/lang/IOException", "file write failed");
3179cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
3180cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3181cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3182cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* write UIn32 value 0 for no of values as place holder */
3183cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    samplesCountBigEndian = 0; /* reusing local var */
3184cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    err = M4OSA_fileWriteData (outFileHandle, (M4OSA_MemAddr8)&samplesCountBigEndian,
3185cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        sizeof(M4OSA_UInt32) );
3186cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (err != M4NO_ERROR) {
3187cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        jniThrowException(pEnv, "java/lang/IOException", "file write failed");
3188cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
3189cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3190cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* loop until EOF */
3191cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    do
3192cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
3193cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        M4OSA_memset((M4OSA_MemAddr8)bufferIn.m_dataAddress,bufferIn.m_bufferSize, 0);
3194cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3195cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        numBytesToRead = samplesCountInBytes;
3196cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3197cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        err =  M4OSA_fileReadData(  inputFileHandle,
3198cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    (M4OSA_MemAddr8)bufferIn.m_dataAddress,
3199cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    &numBytesToRead );
3200cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3201cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (err != M4NO_ERROR) {
3202cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // if out value of bytes-read is 0, break
3203cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            if ( numBytesToRead == 0) {
3204581cad2221cb367e9e3ef6991c565cd37ced994fJames Dong                VIDEOEDIT_LOG_ERROR(ANDROID_LOG_INFO, "VIDEO_EDITOR", "numBytesToRead 0x%lx",
3205cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                numBytesToRead);
3206cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                break; /* stop if file is empty or EOF */
3207cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            }
3208cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
3209cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3210cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        ptr16 = (M4OSA_Int16*)bufferIn.m_dataAddress;
3211cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3212cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        peakVolumeDbValue = 0;
3213cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        index = 0;
3214cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3215cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // loop through half the lenght frame bytes read 'cause its 16 bits samples
3216cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        while (index < (numBytesToRead / 2)) {
3217cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            /* absolute values of 16 bit sample */
3218cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            if (ptr16[index] < 0) {
3219cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                ptr16[index] = -(ptr16[index]);
3220cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            }
3221cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            peakVolumeDbValue = (peakVolumeDbValue > (M4OSA_UInt32)ptr16[index] ?\
3222cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi             peakVolumeDbValue : (M4OSA_UInt32)ptr16[index]);
3223cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            index++;
3224cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
3225cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3226cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // move 7 bits , ignore sign bit
3227cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbValue = (peakVolumeDbValue >> 7);
3228cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        dbValue = logLookUp[(M4OSA_UInt8)dbValue];
3229cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3230cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        err = M4OSA_fileWriteData (outFileHandle, (M4OSA_MemAddr8)&dbValue, sizeof(M4OSA_UInt8) );
3231cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (err != M4NO_ERROR) {
3232cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            VIDEOEDIT_LOG_ERROR(ANDROID_LOG_INFO, "VIDEO_EDITOR",
3233cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi             "M4MA_generateAudioGraphFile : File write failed");
3234cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            break;
3235cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
3236cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3237cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        volumeValuesCount ++;
3238cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        totalBytesRead += numBytesToRead;
3239cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3240cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if ((((totalBytesRead*100)/fileSize)) != prevProgress) {
3241cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            if ( (pContext->threadProgress != prevProgress) && (prevProgress != 0 )) {
3242cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                //pContext->threadProgress = prevProgress;
3243cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                //onWveformProgressUpdateMethodId(prevProgress, 0);
3244cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                //LVME_callAudioGraphOnProgressUpdate(pContext, 0, prevProgress);
3245cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            pEnv->CallVoidMethod(pContext->engine,
3246cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 pContext->onAudioGraphProgressUpdateMethodId,
3247cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                 prevProgress, 0);
3248cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR", "pContext->threadProgress %d",
3249cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                             prevProgress);
3250cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            }
3251cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
3252cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        prevProgress = (((totalBytesRead*100)/fileSize));
3253cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3254cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    } while (numBytesToRead != 0);
3255cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3256581cad2221cb367e9e3ef6991c565cd37ced994fJames Dong    VIDEOEDIT_LOG_ERROR(ANDROID_LOG_INFO, "VIDEO_EDITOR", "loop 0x%lx", volumeValuesCount);
3257cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3258cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* if some error occured in fwrite */
3259cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (numBytesToRead != 0) {
3260cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        //err = -1;
3261cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        jniThrowException(pEnv, "java/lang/IOException", "numBytesToRead != 0 ; file write failed");
3262cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
3263cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3264cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* write the count in place holder after seek */
3265cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    seekPos = sizeof(M4OSA_UInt32);
3266cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    err = M4OSA_fileWriteSeek(outFileHandle, M4OSA_kFileSeekBeginning,
3267cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            &seekPos /* after samples per value */);
3268cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if ( err != M4NO_ERROR) {
3269cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        jniThrowException(pEnv, "java/lang/IOException", "file seek failed");
3270cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    } else {
3271cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        volumeValuesCount = ((volumeValuesCount>>24)&0xff) | // move byte 3 to byte 0
3272cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    ((volumeValuesCount<<8)&0xff0000) | // move byte 1 to byte 2
3273cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    ((volumeValuesCount>>8)&0xff00) |  // move byte 2 to byte 1
3274cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                    ((volumeValuesCount<<24)&0xff000000); // byte 0 to byte 3
3275cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3276cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        err = M4OSA_fileWriteData (outFileHandle, (M4OSA_MemAddr8)&volumeValuesCount,
3277cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                    sizeof(M4OSA_UInt32) );
3278cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if ( err != M4NO_ERROR) {
3279cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            jniThrowException(pEnv, "java/lang/IOException", "file write failed");
3280cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
3281cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
3282cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3283cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /******************************************************************************
3284cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    CLOSE AND FREE ALLOCATIONS
3285cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    *******************************************************************************/
3286cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_free((M4OSA_MemAddr32)bufferIn.m_dataAddress);
3287cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_fileReadClose(inputFileHandle);
3288cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_fileWriteClose(outFileHandle);
3289cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* final finish callback */
3290cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pEnv->CallVoidMethod(pContext->engine, pContext->onAudioGraphProgressUpdateMethodId, 100, 0);
3291cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3292cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* EXIT */
3293cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR", "EXIT - M4MA_generateAudioGraphFile");
3294cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3295cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return err;
3296cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
3297cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3298cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargistatic int videoEditor_generateAudioWaveFormSync (JNIEnv*  pEnv, jobject thiz,
3299cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                  jstring pcmfilePath,
3300cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                  jstring outGraphfilePath,
3301cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                  jint frameDuration, jint channels,
3302cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                                                  jint samplesCount)
3303cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
3304cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    M4OSA_ERR result = M4NO_ERROR;
3305cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ManualEditContext* pContext = M4OSA_NULL;
3306cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool needToBeLoaded = true;
3307cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3308cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR",
3309cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        "videoEditor_generateAudioWaveFormSync() ");
3310cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3311cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* Get the context. */
3312cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    pContext = (ManualEditContext*)videoEditClasses_getContext(&needToBeLoaded, pEnv, thiz);
3313cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pContext == M4OSA_NULL) {
3314cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR",
3315cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            "videoEditor_generateAudioWaveFormSync() - pContext is NULL ");
3316cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
3317cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3318cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR",
3319cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        "videoEditor_generateAudioWaveFormSync Retrieving pStringOutAudioGraphFile");
3320cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3321cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    const char *pPCMFilePath = pEnv->GetStringUTFChars(pcmfilePath, NULL);
3322cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pPCMFilePath == M4OSA_NULL) {
3323cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (pEnv != NULL) {
3324cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            jniThrowException(pEnv, "java/lang/RuntimeException",
3325cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                "Input string PCMFilePath is null");
3326cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
3327cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
3328cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3329cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    const char *pStringOutAudioGraphFile = pEnv->GetStringUTFChars(outGraphfilePath, NULL);
3330cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pStringOutAudioGraphFile == M4OSA_NULL) {
3331cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (pEnv != NULL) {
3332cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            jniThrowException(pEnv, "java/lang/RuntimeException",
3333cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                "Input string outGraphfilePath is null");
3334cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
3335cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
3336cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3337cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_API(ANDROID_LOG_INFO, "VIDEO_EDITOR",
3338cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        "videoEditor_generateAudioWaveFormSync Generate the waveform data %s %d %d %d",
3339cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pStringOutAudioGraphFile, frameDuration, channels, samplesCount);
3340cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3341cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    /* Generate the waveform */
3342cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    result = M4MA_generateAudioGraphFile(pEnv, (M4OSA_Char*) pPCMFilePath,
3343cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4OSA_Char*) pStringOutAudioGraphFile,
3344cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4OSA_UInt32) samplesCount,
3345cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4OSA_UInt32) channels,
3346cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        (M4OSA_UInt32)frameDuration,
3347cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pContext);
3348cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3349cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pStringOutAudioGraphFile != NULL) {
3350cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        pEnv->ReleaseStringUTFChars(outGraphfilePath, pStringOutAudioGraphFile);
3351cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
3352cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3353cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR",
3354cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        "videoEditor_generateAudioWaveFormSync pContext->bSkipState ");
3355cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3356cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return result;
3357cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
3358cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3359cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi/******** End Audio Graph *******/
3360cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargijint JNI_OnLoad(
3361cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                JavaVM*                             pVm,
3362cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                void*                               pReserved)
3363cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi{
3364cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    void* pEnv         = NULL;
3365cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    bool  needToBeInitialized = true;
3366cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    jint  result      = -1;
3367cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3368cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    VIDEOEDIT_LOG_FUNCTION(ANDROID_LOG_INFO, "VIDEO_EDITOR", "JNI_OnLoad()");
3369cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3370cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Add a text marker (the condition must always be true).
3371cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    ADD_TEXT_MARKER_FUN(NULL != pVm)
3372cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3373cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Check the JNI version.
3374cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    if (pVm->GetEnv(&pEnv, JNI_VERSION_1_4) == JNI_OK)
3375cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    {
3376cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Add a code marker (the condition must always be true).
3377cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        ADD_CODE_MARKER_FUN(NULL != pEnv)
3378cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3379cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        // Register the manual edit JNI methods.
3380cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        if (videoEditor_registerManualEditMethods((JNIEnv*)pEnv) == 0)
3381cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        {
3382cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            // Initialize the classes.
3383cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            videoEditClasses_init(&needToBeInitialized, (JNIEnv*)pEnv);
3384cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            if (needToBeInitialized)
3385cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            {
3386cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                // Success, return valid version number.
3387cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi                result = JNI_VERSION_1_4;
3388cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi            }
3389cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi        }
3390cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    }
3391cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3392cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    // Return the result.
3393cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi    return(result);
3394cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi}
3395cd196d3727db641e581d4223815367a5ca5d5637Dharmaray Kundargi
3396