summaryrefslogtreecommitdiff
Diffstat
-rw-r--r--tv_callback.h7
-rw-r--r--tv_input.cpp96
-rw-r--r--tvapi/android/include/ITv.h34
-rw-r--r--tvapi/android/include/ITvClient.h12
-rw-r--r--tvapi/android/include/ITvService.h18
-rw-r--r--tvapi/android/include/TvClient.h5
-rw-r--r--tvapi/android/include/tvcmd.h1180
-rw-r--r--tvapi/android/jni/cfbc_jni.cpp214
-rw-r--r--tvapi/android/jni/cfbc_test.cpp64
-rw-r--r--tvapi/android/jni/com_droidlogic_app_tv_TvControlManager.cpp666
-rw-r--r--tvapi/android/libtvbinder/ITv.cpp246
-rw-r--r--tvapi/android/libtvbinder/ITvClient.cpp78
-rw-r--r--tvapi/android/libtvbinder/ITvService.cpp56
-rw-r--r--tvapi/android/libtvbinder/TvClient.cpp54
-rw-r--r--tvapi/android/tv/TvPlay.cpp36
-rw-r--r--tvapi/android/tv/TvPlay.h2
-rw-r--r--tvapi/android/tvserver/TvService.cpp8700
-rw-r--r--tvapi/android/tvserver/TvService.h107
-rw-r--r--tvapi/android/tvserver/main.cpp12
-rw-r--r--tvapi/android/tvserver/tv_callback.h25
-rw-r--r--tvapi/libtv/audio/CAudioCustomerCtrl.cpp170
-rw-r--r--tvapi/libtv/audio/CAudioCustomerCtrl.h32
-rw-r--r--tvapi/libtv/audio/CTvAudio.h52
-rw-r--r--tvapi/libtv/audio/audio_alsa.cpp1004
-rw-r--r--tvapi/libtv/audio/audio_alsa.h164
-rw-r--r--tvapi/libtv/audio/audio_effect.cpp82
-rw-r--r--tvapi/libtv/audio/audio_effect.h34
-rw-r--r--tvapi/libtv/include/amstream.h142
-rw-r--r--tvapi/libtv/include/cm.h188
-rw-r--r--tvapi/libtv/include/hdmirx_cec.h492
-rw-r--r--tvapi/libtv/include/ve.h342
-rw-r--r--tvapi/libtv/tv/AutoBackLight.cpp280
-rw-r--r--tvapi/libtv/tv/AutoBackLight.h44
-rw-r--r--tvapi/libtv/tv/CAutoPQparam.cpp172
-rw-r--r--tvapi/libtv/tv/CAutoPQparam.h26
-rw-r--r--tvapi/libtv/tv/CAv.cpp612
-rw-r--r--tvapi/libtv/tv/CAv.h188
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.cpp2670
-rw-r--r--tvapi/libtv/tv/CFbcCommunication.h716
-rw-r--r--tvapi/libtv/tv/CFrontEnd.cpp964
-rw-r--r--tvapi/libtv/tv/CFrontEnd.h236
-rw-r--r--tvapi/libtv/tv/CTv.cpp2174
-rw-r--r--tvapi/libtv/tv/CTv.h1470
-rw-r--r--tvapi/libtv/tv/CTvBooking.cpp170
-rw-r--r--tvapi/libtv/tv/CTvBooking.h94
-rw-r--r--tvapi/libtv/tv/CTvDmx.cpp8
-rw-r--r--tvapi/libtv/tv/CTvDmx.h12
-rw-r--r--tvapi/libtv/tv/CTvEpg.cpp258
-rw-r--r--tvapi/libtv/tv/CTvEpg.h276
-rw-r--r--tvapi/libtv/tv/CTvEv.cpp2
-rw-r--r--tvapi/libtv/tv/CTvEv.h322
-rw-r--r--tvapi/libtv/tv/CTvRecord.cpp368
-rw-r--r--tvapi/libtv/tv/CTvRecord.h70
-rw-r--r--tvapi/libtv/tv/CTvScanner.cpp1934
-rw-r--r--tvapi/libtv/tv/CTvScanner.h418
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.cpp1228
-rw-r--r--tvapi/libtv/tv/CTvScreenCapture.h142
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.cpp708
-rw-r--r--tvapi/libtv/tv/CTvSubtitle.h430
-rw-r--r--tvapi/libtv/tv/CTvTime.h134
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.cpp250
-rw-r--r--tvapi/libtv/tv/CTvVchipCheck.h40
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.cpp974
-rw-r--r--tvapi/libtv/tv/CUpgradeFBC.h104
-rw-r--r--tvapi/libtv/tv/ScreenCatch.cpp638
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.cpp558
-rw-r--r--tvapi/libtv/tvconfig/CIniFile.h76
-rw-r--r--tvapi/libtv/tvconfig/tvconfig.cpp28
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.cpp408
-rw-r--r--tvapi/libtv/tvdb/CTvChannel.h478
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.cpp302
-rw-r--r--tvapi/libtv/tvdb/CTvDatabase.h112
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.cpp714
-rw-r--r--tvapi/libtv/tvdb/CTvDimension.h134
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.cpp322
-rw-r--r--tvapi/libtv/tvdb/CTvEvent.h112
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.cpp4
-rw-r--r--tvapi/libtv/tvdb/CTvGroup.h14
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.cpp1322
-rw-r--r--tvapi/libtv/tvdb/CTvProgram.h988
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.cpp228
-rw-r--r--tvapi/libtv/tvdb/CTvRegion.h30
-rw-r--r--tvapi/libtv/tvin/CHDMIRxCEC.cpp830
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.cpp438
-rw-r--r--tvapi/libtv/tvin/CSourceConnectDetect.h76
-rw-r--r--tvapi/libtv/tvin/CTvin.cpp4452
-rw-r--r--tvapi/libtv/tvin/CTvin.h2116
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.cpp6
-rw-r--r--tvapi/libtv/tvsetting/CBlobDevice.h72
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.cpp12
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceE2prom.h48
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.cpp66
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceFile.h20
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.cpp146
-rw-r--r--tvapi/libtv/tvsetting/CBlobDeviceRam.h40
-rw-r--r--tvapi/libtv/tvsetting/CTvSetting.cpp2168
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.cpp38
-rw-r--r--tvapi/libtv/tvsetting/CTvSettingDeviceFactory.h8
-rw-r--r--tvapi/libtv/tvsetting/TvKeyData.cpp1792
-rw-r--r--tvapi/libtv/tvsetting/audio_cfg.cpp958
-rw-r--r--tvapi/libtv/tvutils/CCondition.h84
-rw-r--r--tvapi/libtv/tvutils/CFile.cpp261
-rw-r--r--tvapi/libtv/tvutils/CFile.h50
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.cpp6
-rw-r--r--tvapi/libtv/tvutils/CHdmiCecCmd.h6
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.cpp146
-rw-r--r--tvapi/libtv/tvutils/CMsgQueue.h40
-rw-r--r--tvapi/libtv/tvutils/CMutex.h112
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.cpp118
-rw-r--r--tvapi/libtv/tvutils/CSerialCommunication.h60
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.cpp568
-rw-r--r--tvapi/libtv/tvutils/CSerialPort.h42
-rw-r--r--tvapi/libtv/tvutils/CSqlite.cpp126
-rw-r--r--tvapi/libtv/tvutils/CSqlite.h288
-rw-r--r--tvapi/libtv/tvutils/CThread.cpp212
-rw-r--r--tvapi/libtv/tvutils/CThread.h76
-rw-r--r--tvapi/libtv/tvutils/CTvInput.cpp204
-rw-r--r--tvapi/libtv/tvutils/CTvInput.h46
-rw-r--r--tvapi/libtv/tvutils/serial_base.cpp560
-rw-r--r--tvapi/libtv/tvutils/serial_operate.cpp336
-rw-r--r--tvapi/libtv/tvutils/serial_operate.h42
-rw-r--r--tvapi/libtv/tvutils/tvutils.cpp2813
-rw-r--r--tvapi/libtv/tvutils/tvutils.h44
-rw-r--r--tvapi/libtv/tvutils/zepoll.cpp66
-rw-r--r--tvapi/libtv/tvutils/zepoll.h54
-rw-r--r--tvapi/libtv/version/version.cpp50
-rw-r--r--tvapi/libtv/vpp/CPQdb.cpp618
-rw-r--r--tvapi/libtv/vpp/CPQdb.h232
-rw-r--r--tvapi/libtv/vpp/CVpp.cpp724
-rw-r--r--tvapi/libtv/vpp/CVpp.h676
-rw-r--r--tvapi/libtv/vpp/pqdata.cpp216
-rw-r--r--tvapi/tvtests/comm_test.cpp42
-rw-r--r--tvapi/tvtests/ssm_test.cpp320
-rw-r--r--tvapi/tvtests/tvconfig_test.cpp560
134 files changed, 31073 insertions, 30287 deletions
diff --git a/tvapi/android/jni/com_droidlogic_app_tv_TvControlManager.cpp b/tvapi/android/jni/com_droidlogic_app_tv_TvControlManager.cpp
index 0f815f2..f0fb381 100644
--- a/tvapi/android/jni/com_droidlogic_app_tv_TvControlManager.cpp
+++ b/tvapi/android/jni/com_droidlogic_app_tv_TvControlManager.cpp
@@ -18,8 +18,8 @@
using namespace android;
struct fields_t {
- jfieldID context;
- jmethodID post_event;
+ jfieldID context;
+ jmethodID post_event;
};
#ifdef LOG_TAG
@@ -31,444 +31,444 @@ static fields_t fields;
static Mutex sLock;
class JNITvContext: public TvListener {
public:
- JNITvContext(JNIEnv *env, jobject weak_this, jclass clazz, const sp<TvClient> &tv);
- ~JNITvContext()
- {
- release();
- }
- virtual void notify(int32_t msgType, const Parcel &p);
- void addCallbackBuffer(JNIEnv *env, jbyteArray cbb);
- sp<TvClient> getTv()
- {
- Mutex::Autolock _l(mLock);
- return mTv;
- }
- void release();
- Parcel *mExtParcel;
- SkBitmap *pSubBmp;//for UI subtitle Bitmap
- sp<MemoryBase> mSubMemBase;//for subtitle shar memory to tvapi
+ JNITvContext(JNIEnv *env, jobject weak_this, jclass clazz, const sp<TvClient> &tv);
+ ~JNITvContext()
+ {
+ release();
+ }
+ virtual void notify(int32_t msgType, const Parcel &p);
+ void addCallbackBuffer(JNIEnv *env, jbyteArray cbb);
+ sp<TvClient> getTv()
+ {
+ Mutex::Autolock _l(mLock);
+ return mTv;
+ }
+ void release();
+ Parcel *mExtParcel;
+ SkBitmap *pSubBmp;//for UI subtitle Bitmap
+ sp<MemoryBase> mSubMemBase;//for subtitle shar memory to tvapi
private:
- jobject mTvJObjectWeak; // weak reference to java object
- jclass mTvJClass; // strong reference to java class
- sp<TvClient> mTv; // strong reference to native object
- Mutex mLock;
-
- Vector<jbyteArray> mCallbackBuffers; // Global reference application managed byte[]
- bool mManualBufferMode; // Whether to use application managed buffers.
- bool mManualTvCallbackSet; // Whether the callback has been set, used to reduce unnecessary calls to set the callback.
+ jobject mTvJObjectWeak; // weak reference to java object
+ jclass mTvJClass; // strong reference to java class
+ sp<TvClient> mTv; // strong reference to native object
+ Mutex mLock;
+
+ Vector<jbyteArray> mCallbackBuffers; // Global reference application managed byte[]
+ bool mManualBufferMode; // Whether to use application managed buffers.
+ bool mManualTvCallbackSet; // Whether the callback has been set, used to reduce unnecessary calls to set the callback.
};
sp<TvClient> get_native_tv(JNIEnv *env, jobject thiz, JNITvContext **pContext)
{
- sp<TvClient> tv;
- Mutex::Autolock _l(sLock);
- JNITvContext *context = reinterpret_cast<JNITvContext *>(env->GetIntField(thiz, fields.context));
- if (context != NULL) {
- tv = context->getTv();
- }
- if (tv == 0) {
- jniThrowException(env, "java/lang/RuntimeException", "Method called after release()");
- }
-
- if (pContext != NULL) *pContext = context;
- return tv;
+ sp<TvClient> tv;
+ Mutex::Autolock _l(sLock);
+ JNITvContext *context = reinterpret_cast<JNITvContext *>(env->GetIntField(thiz, fields.context));
+ if (context != NULL) {
+ tv = context->getTv();
+ }
+ if (tv == 0) {
+ jniThrowException(env, "java/lang/RuntimeException", "Method called after release()");
+ }
+
+ if (pContext != NULL) *pContext = context;
+ return tv;
}
JNITvContext::JNITvContext(JNIEnv *env, jobject weak_this, jclass clazz, const sp<TvClient> &tv)
{
- mTvJObjectWeak = env->NewGlobalRef(weak_this);
- mTvJClass = (jclass)env->NewGlobalRef(clazz);
- mTv = tv;
- ALOGD("tvjni----------------------JNITvContext::JNITvContext(");
- mManualBufferMode = false;
- mManualTvCallbackSet = false;
- pSubBmp = NULL;
- mSubMemBase = NULL;
- //mExtParcel = parcelForJavaObject(env, ext_parcel);
+ mTvJObjectWeak = env->NewGlobalRef(weak_this);
+ mTvJClass = (jclass)env->NewGlobalRef(clazz);
+ mTv = tv;
+ ALOGD("tvjni----------------------JNITvContext::JNITvContext(");
+ mManualBufferMode = false;
+ mManualTvCallbackSet = false;
+ pSubBmp = NULL;
+ mSubMemBase = NULL;
+ //mExtParcel = parcelForJavaObject(env, ext_parcel);
}
void JNITvContext::release()
{
- ALOGD("release");
- Mutex::Autolock _l(mLock);
- JNIEnv *env = AndroidRuntime::getJNIEnv();
-
- if (mTvJObjectWeak != NULL) {
- env->DeleteGlobalRef(mTvJObjectWeak);
- mTvJObjectWeak = NULL;
- }
- if (mTvJClass != NULL) {
- env->DeleteGlobalRef(mTvJClass);
- mTvJClass = NULL;
- }
- if (pSubBmp != NULL) {
- pSubBmp = NULL;
- }
- mTv.clear();
+ ALOGD("release");
+ Mutex::Autolock _l(mLock);
+ JNIEnv *env = AndroidRuntime::getJNIEnv();
+
+ if (mTvJObjectWeak != NULL) {
+ env->DeleteGlobalRef(mTvJObjectWeak);
+ mTvJObjectWeak = NULL;
+ }
+ if (mTvJClass != NULL) {
+ env->DeleteGlobalRef(mTvJClass);
+ mTvJClass = NULL;
+ }
+ if (pSubBmp != NULL) {
+ pSubBmp = NULL;
+ }
+ mTv.clear();
}
// connect to tv service
static void com_droidlogic_app_tv_TvControlManager_native_setup(JNIEnv *env, jobject thiz, jobject weak_this)
{
- sp<TvClient> tv = TvClient::connect();
+ sp<TvClient> tv = TvClient::connect();
- ALOGD("com_droidlogic_app_tv_TvControlManager_native_setup.");
+ ALOGD("com_droidlogic_app_tv_TvControlManager_native_setup.");
- if (tv == NULL) {
- jniThrowException(env, "java/lang/RuntimeException", "Fail to connect to tv service");
- return;
- }
+ if (tv == NULL) {
+ jniThrowException(env, "java/lang/RuntimeException", "Fail to connect to tv service");
+ return;
+ }
- // make sure tv amlogic is alive
- if (tv->getStatus() != NO_ERROR) {
- jniThrowException(env, "java/lang/RuntimeException", "Tv initialization failed!");
- return;
- }
+ // make sure tv amlogic is alive
+ if (tv->getStatus() != NO_ERROR) {
+ jniThrowException(env, "java/lang/RuntimeException", "Tv initialization failed!");
+ return;
+ }
- jclass clazz = env->GetObjectClass(thiz);
- if (clazz == NULL) {
- jniThrowException(env, "java/lang/RuntimeException", "Can't find com/droidlogic/app/tv/TvControlManager!");
- return;
- }
+ jclass clazz = env->GetObjectClass(thiz);
+ if (clazz == NULL) {
+ jniThrowException(env, "java/lang/RuntimeException", "Can't find com/droidlogic/app/tv/TvControlManager!");
+ return;
+ }
- sp<JNITvContext> context = new JNITvContext(env, weak_this, clazz, tv);
- context->incStrong(thiz);
- tv->setListener(context);
+ sp<JNITvContext> context = new JNITvContext(env, weak_this, clazz, tv);
+ context->incStrong(thiz);
+ tv->setListener(context);
- env->SetIntField(thiz, fields.context, (int)context.get());
+ env->SetIntField(thiz, fields.context, (int)context.get());
}
static void com_droidlogic_app_tv_TvControlManager_release(JNIEnv *env, jobject thiz)
{
- // TODO: Change to LOGE
- JNITvContext *context = NULL;
- sp<TvClient> tv;
- {
- Mutex::Autolock _l(sLock);
- context = reinterpret_cast<JNITvContext *>(env->GetIntField(thiz, fields.context));
-
- // Make sure we do not attempt to callback on a deleted Java object.
- env->SetIntField(thiz, fields.context, 0);
- }
-
- ALOGD("release tv");
-
- // clean up if release has not been called before
- if (context != NULL) {
- tv = context->getTv();
- context->release();
- ALOGD("native_release: context=%p tv=%p", context, tv.get());
-
- // clear callbacks
- if (tv != NULL) {
- //tv->setPreviewCallbackFlags(FRAME_CALLBACK_FLAG_NOOP);
- tv->disconnect();
- }
-
- // remove context to prevent further Java access
- context->decStrong(thiz);
- }
+ // TODO: Change to LOGE
+ JNITvContext *context = NULL;
+ sp<TvClient> tv;
+ {
+ Mutex::Autolock _l(sLock);
+ context = reinterpret_cast<JNITvContext *>(env->GetIntField(thiz, fields.context));
+
+ // Make sure we do not attempt to callback on a deleted Java object.
+ env->SetIntField(thiz, fields.context, 0);
+ }
+
+ ALOGD("release tv");
+
+ // clean up if release has not been called before
+ if (context != NULL) {
+ tv = context->getTv();
+ context->release();
+ ALOGD("native_release: context=%p tv=%p", context, tv.get());
+
+ // clear callbacks
+ if (tv != NULL) {
+ //tv->setPreviewCallbackFlags(FRAME_CALLBACK_FLAG_NOOP);
+ tv->disconnect();
+ }
+
+ // remove context to prevent further Java access
+ context->decStrong(thiz);
+ }
}
void JNITvContext::notify(int32_t msgType, const Parcel &p)
{
- // VM pointer will be NULL if object is released
- Mutex::Autolock _l(mLock);
- if (mTvJObjectWeak == NULL) {
- ALOGW("callback on dead tv object");
- return;
- }
- if (msgType == SUBTITLE_UPDATE_CALLBACK) {
- if (pSubBmp) {
- SkAutoLockPixels alp(*pSubBmp);
- char *pDst = (char *) pSubBmp->getPixels();
- char *pBuf = (char *) mSubMemBase->pointer();
- for (int i = 0; i < pSubBmp->width() * pSubBmp->height() * 4; i++) {
- pDst[i] = pBuf[i];
- }
- pSubBmp->notifyPixelsChanged();
- }
- }
-
- JNIEnv *env = AndroidRuntime::getJNIEnv();
-
- jobject jParcel = createJavaParcelObject(env);
- if (jParcel != NULL) {
- Parcel *nativeParcel = parcelForJavaObject(env, jParcel);
- nativeParcel->write(p.data(), p.dataSize());
- env->CallStaticVoidMethod(mTvJClass, fields.post_event, mTvJObjectWeak, msgType, jParcel);
- env->DeleteLocalRef(jParcel);
- }
+ // VM pointer will be NULL if object is released
+ Mutex::Autolock _l(mLock);
+ if (mTvJObjectWeak == NULL) {
+ ALOGW("callback on dead tv object");
+ return;
+ }
+ if (msgType == SUBTITLE_UPDATE_CALLBACK) {
+ if (pSubBmp) {
+ SkAutoLockPixels alp(*pSubBmp);
+ char *pDst = (char *) pSubBmp->getPixels();
+ char *pBuf = (char *) mSubMemBase->pointer();
+ for (int i = 0; i < pSubBmp->width() * pSubBmp->height() * 4; i++) {
+ pDst[i] = pBuf[i];
+ }
+ pSubBmp->notifyPixelsChanged();
+ }
+ }
+
+ JNIEnv *env = AndroidRuntime::getJNIEnv();
+
+ jobject jParcel = createJavaParcelObject(env);
+ if (jParcel != NULL) {
+ Parcel *nativeParcel = parcelForJavaObject(env, jParcel);
+ nativeParcel->write(p.data(), p.dataSize());
+ env->CallStaticVoidMethod(mTvJClass, fields.post_event, mTvJObjectWeak, msgType, jParcel);
+ env->DeleteLocalRef(jParcel);
+ }
}
void JNITvContext::addCallbackBuffer(JNIEnv *env, jbyteArray cbb)
{
- if (cbb != NULL) {
- Mutex::Autolock _l(mLock);
- jbyteArray callbackBuffer = (jbyteArray)env->NewGlobalRef(cbb);
- mCallbackBuffers.push(cbb);
- ALOGD("Adding callback buffer to queue, %d total", mCallbackBuffers.size());
- } else {
- ALOGE("Null byte array!");
- }
+ if (cbb != NULL) {
+ Mutex::Autolock _l(mLock);
+ jbyteArray callbackBuffer = (jbyteArray)env->NewGlobalRef(cbb);
+ mCallbackBuffers.push(cbb);
+ ALOGD("Adding callback buffer to queue, %d total", mCallbackBuffers.size());
+ } else {
+ ALOGE("Null byte array!");
+ }
}
static jint com_droidlogic_app_tv_TvControlManager_processCmd(JNIEnv *env, jobject thiz, jobject pObj, jobject rObj)
{
- sp<TvClient> tv = get_native_tv(env, thiz, NULL);
- if (tv == 0) return -1;
+ sp<TvClient> tv = get_native_tv(env, thiz, NULL);
+ if (tv == 0) return -1;
- Parcel *p = parcelForJavaObject(env, pObj);
- //jclass clazz;
- //clazz = env->FindClass("android/os/Parcel");
- //LOG_FATAL_IF(clazz == NULL, "Unable to find class android.os.Parcel");
+ Parcel *p = parcelForJavaObject(env, pObj);
+ //jclass clazz;
+ //clazz = env->FindClass("android/os/Parcel");
+ //LOG_FATAL_IF(clazz == NULL, "Unable to find class android.os.Parcel");
- //jmethodID mConstructor = env->GetMethodID(clazz, "<init>", "(I)V");
- //jobject replayobj = env->NewObject(clazz, mConstructor, 0);
- Parcel *r = parcelForJavaObject(env, rObj);
+ //jmethodID mConstructor = env->GetMethodID(clazz, "<init>", "(I)V");
+ //jobject replayobj = env->NewObject(clazz, mConstructor, 0);
+ Parcel *r = parcelForJavaObject(env, rObj);
- return tv->processCmd(*p, r);
- //if ( != NO_ERROR) {
- // jniThrowException(env, "java/lang/RuntimeException", "StartTv failed");
- // return -1;
- // }
- //return 0;
+ return tv->processCmd(*p, r);
+ //if ( != NO_ERROR) {
+ // jniThrowException(env, "java/lang/RuntimeException", "StartTv failed");
+ // return -1;
+ // }
+ //return 0;
}
static void com_droidlogic_app_tv_TvControlManager_addCallbackBuffer(JNIEnv *env, jobject thiz, jbyteArray bytes)
{
- JNITvContext *context = reinterpret_cast<JNITvContext *>(env->GetIntField(thiz, fields.context));
+ JNITvContext *context = reinterpret_cast<JNITvContext *>(env->GetIntField(thiz, fields.context));
- ALOGD("addCallbackBuffer");
- if (context != NULL) {
- context->addCallbackBuffer(env, bytes);
- }
+ ALOGD("addCallbackBuffer");
+ if (context != NULL) {
+ context->addCallbackBuffer(env, bytes);
+ }
}
static void com_droidlogic_app_tv_TvControlManager_reconnect(JNIEnv *env, jobject thiz)
{
- sp<TvClient> tv = get_native_tv(env, thiz, NULL);
- if (tv == 0) return;
+ sp<TvClient> tv = get_native_tv(env, thiz, NULL);
+ if (tv == 0) return;
- if (tv->reconnect() != NO_ERROR) {
- jniThrowException(env, "java/io/IOException", "reconnect failed");
- return;
- }
+ if (tv->reconnect() != NO_ERROR) {
+ jniThrowException(env, "java/io/IOException", "reconnect failed");
+ return;
+ }
}
static void com_droidlogic_app_tv_TvControlManager_lock(JNIEnv *env, jobject thiz)
{
- sp<TvClient> tv = get_native_tv(env, thiz, NULL);
- if (tv == 0) return;
+ sp<TvClient> tv = get_native_tv(env, thiz, NULL);
+ if (tv == 0) return;
- ALOGD("lock");
+ ALOGD("lock");
- if (tv->lock() != NO_ERROR) {
- jniThrowException(env, "java/lang/RuntimeException", "lock failed");
- }
+ if (tv->lock() != NO_ERROR) {
+ jniThrowException(env, "java/lang/RuntimeException", "lock failed");
+ }
}
static void com_droidlogic_app_tv_TvControlManager_unlock(JNIEnv *env, jobject thiz)
{
- sp<TvClient> tv = get_native_tv(env, thiz, NULL);
- if (tv == 0) return;
+ sp<TvClient> tv = get_native_tv(env, thiz, NULL);
+ if (tv == 0) return;
- ALOGD("unlock");
+ ALOGD("unlock");
- if (tv->unlock() != NO_ERROR) {
- jniThrowException(env, "java/lang/RuntimeException", "unlock failed");
- }
+ if (tv->unlock() != NO_ERROR) {
+ jniThrowException(env, "java/lang/RuntimeException", "unlock failed");
+ }
}
static void com_droidlogic_app_tv_TvControlManager_create_subtitle_bitmap(JNIEnv *env, jobject thiz, jobject bmpobj)
{
- ALOGD("create subtitle bmp");
- JNITvContext *context = reinterpret_cast<JNITvContext *>(env->GetIntField(thiz, fields.context));
- sp<TvClient> tv = get_native_tv(env, thiz, NULL);
- if (tv == 0) return;
-
- //get skbitmap
- jclass bmp_clazz;
- jfieldID skbmp_fid;
- jint hbmp;
- bmp_clazz = env->FindClass("android/graphics/Bitmap");
- skbmp_fid = env->GetFieldID(bmp_clazz, "mNativeBitmap", "I");
- hbmp = env->GetIntField(bmpobj, skbmp_fid);
- context->pSubBmp = reinterpret_cast<SkBitmap *>(hbmp);
- env->DeleteLocalRef(bmp_clazz);
-
- //alloc share mem
- sp<MemoryHeapBase> MemHeap = new MemoryHeapBase(context->pSubBmp->width()*context->pSubBmp->height() * 4, 0, "subtitle bmp");
- ALOGD("heap id = %d", MemHeap->getHeapID());
- if (MemHeap->getHeapID() < 0) {
- return;
- }
- context->pSubBmp->lockPixels();
- context->mSubMemBase = new MemoryBase(MemHeap, 0, context->pSubBmp->width()*context->pSubBmp->height() * 4);
-
-
- //send share mem to server
- tv->createSubtitle(context->mSubMemBase);
- return;
+ ALOGD("create subtitle bmp");
+ JNITvContext *context = reinterpret_cast<JNITvContext *>(env->GetIntField(thiz, fields.context));
+ sp<TvClient> tv = get_native_tv(env, thiz, NULL);
+ if (tv == 0) return;
+
+ //get skbitmap
+ jclass bmp_clazz;
+ jfieldID skbmp_fid;
+ jint hbmp;
+ bmp_clazz = env->FindClass("android/graphics/Bitmap");
+ skbmp_fid = env->GetFieldID(bmp_clazz, "mNativeBitmap", "I");
+ hbmp = env->GetIntField(bmpobj, skbmp_fid);
+ context->pSubBmp = reinterpret_cast<SkBitmap *>(hbmp);
+ env->DeleteLocalRef(bmp_clazz);
+
+ //alloc share mem
+ sp<MemoryHeapBase> MemHeap = new MemoryHeapBase(context->pSubBmp->width()*context->pSubBmp->height() * 4, 0, "subtitle bmp");
+ ALOGD("heap id = %d", MemHeap->getHeapID());
+ if (MemHeap->getHeapID() < 0) {
+ return;
+ }
+ context->pSubBmp->lockPixels();
+ context->mSubMemBase = new MemoryBase(MemHeap, 0, context->pSubBmp->width()*context->pSubBmp->height() * 4);
+
+
+ //send share mem to server
+ tv->createSubtitle(context->mSubMemBase);
+ return;
}
static void com_droidlogic_app_tv_TvControlManager_create_video_frame_bitmap(JNIEnv *env, jobject thiz, jobject bmpobj, jint inputSourceMode, jint iCapVideoLayer )
{
- ALOGD("create video frame bmp");
- sp<TvClient> tv = get_native_tv(env, thiz, NULL);
- if (tv == 0) return;
-
- //get skbitmap
- jclass bmp_clazz;
- jfieldID skbmp_fid;
- jint hbmp;
- bmp_clazz = env->FindClass("android/graphics/Bitmap");
- skbmp_fid = env->GetFieldID(bmp_clazz, "mNativeBitmap", "I");
- hbmp = env->GetIntField(bmpobj, skbmp_fid);
- SkBitmap *pSkBmp = reinterpret_cast<SkBitmap *>(hbmp);
- ALOGD("pSkBmp = %d", hbmp);
- ALOGD("bmp width = %d height = %d", pSkBmp->width(), pSkBmp->height());
- env->DeleteLocalRef(bmp_clazz);
-
- //alloc share mem
- sp<MemoryHeapBase> MemHeap = new MemoryHeapBase(1920 * 1080 * 4, 0, "video frame bmp");
- ALOGD("heap id = %d", MemHeap->getHeapID());
- if (MemHeap->getHeapID() < 0) {
- return;
- }
- sp<MemoryBase> MemBase = new MemoryBase(MemHeap, 0, 1920 * 1080 * 4);
- pSkBmp->setPixels(MemBase->pointer());
-
-
- //send share mem to server
- tv->createVideoFrame(MemBase, inputSourceMode, iCapVideoLayer);
- return;
+ ALOGD("create video frame bmp");
+ sp<TvClient> tv = get_native_tv(env, thiz, NULL);
+ if (tv == 0) return;
+
+ //get skbitmap
+ jclass bmp_clazz;
+ jfieldID skbmp_fid;
+ jint hbmp;
+ bmp_clazz = env->FindClass("android/graphics/Bitmap");
+ skbmp_fid = env->GetFieldID(bmp_clazz, "mNativeBitmap", "I");
+ hbmp = env->GetIntField(bmpobj, skbmp_fid);
+ SkBitmap *pSkBmp = reinterpret_cast<SkBitmap *>(hbmp);
+ ALOGD("pSkBmp = %d", hbmp);
+ ALOGD("bmp width = %d height = %d", pSkBmp->width(), pSkBmp->height());
+ env->DeleteLocalRef(bmp_clazz);
+
+ //alloc share mem
+ sp<MemoryHeapBase> MemHeap = new MemoryHeapBase(1920 * 1080 * 4, 0, "video frame bmp");
+ ALOGD("heap id = %d", MemHeap->getHeapID());
+ if (MemHeap->getHeapID() < 0) {
+ return;
+ }
+ sp<MemoryBase> MemBase = new MemoryBase(MemHeap, 0, 1920 * 1080 * 4);
+ pSkBmp->setPixels(MemBase->pointer());
+
+
+ //send share mem to server
+ tv->createVideoFrame(MemBase, inputSourceMode, iCapVideoLayer);
+ return;
}
//-------------------------------------------------
static JNINativeMethod camMethods[] = {
- {
- "native_setup",
- "(Ljava/lang/Object;)V",
- (void *)com_droidlogic_app_tv_TvControlManager_native_setup
- },
- {
- "native_release",
- "()V",
- (void *)com_droidlogic_app_tv_TvControlManager_release
- },
- {
- "processCmd",
- "(Landroid/os/Parcel;Landroid/os/Parcel;)I",
- (void *)com_droidlogic_app_tv_TvControlManager_processCmd
- },
- {
- "addCallbackBuffer",
- "([B)V",
- (void *)com_droidlogic_app_tv_TvControlManager_addCallbackBuffer
- },
- {
- "reconnect",
- "()V",
- (void *)com_droidlogic_app_tv_TvControlManager_reconnect
- },
- {
- "lock",
- "()V",
- (void *)com_droidlogic_app_tv_TvControlManager_lock
- },
- {
- "unlock",
- "()V",
- (void *)com_droidlogic_app_tv_TvControlManager_unlock
- },
- {
- "native_create_subtitle_bitmap",
- "(Ljava/lang/Object;)V",
- (void *)com_droidlogic_app_tv_TvControlManager_create_subtitle_bitmap
- },
- {
- "native_create_video_frame_bitmap",
- "(Ljava/lang/Object;)V",
- (void *)com_droidlogic_app_tv_TvControlManager_create_video_frame_bitmap
- },
+ {
+ "native_setup",
+ "(Ljava/lang/Object;)V",
+ (void *)com_droidlogic_app_tv_TvControlManager_native_setup
+ },
+ {
+ "native_release",
+ "()V",
+ (void *)com_droidlogic_app_tv_TvControlManager_release
+ },
+ {
+ "processCmd",
+ "(Landroid/os/Parcel;Landroid/os/Parcel;)I",
+ (void *)com_droidlogic_app_tv_TvControlManager_processCmd
+ },
+ {
+ "addCallbackBuffer",
+ "([B)V",
+ (void *)com_droidlogic_app_tv_TvControlManager_addCallbackBuffer
+ },
+ {
+ "reconnect",
+ "()V",
+ (void *)com_droidlogic_app_tv_TvControlManager_reconnect
+ },
+ {
+ "lock",
+ "()V",
+ (void *)com_droidlogic_app_tv_TvControlManager_lock
+ },
+ {
+ "unlock",
+ "()V",
+ (void *)com_droidlogic_app_tv_TvControlManager_unlock
+ },
+ {
+ "native_create_subtitle_bitmap",
+ "(Ljava/lang/Object;)V",
+ (void *)com_droidlogic_app_tv_TvControlManager_create_subtitle_bitmap
+ },
+ {
+ "native_create_video_frame_bitmap",
+ "(Ljava/lang/Object;)V",
+ (void *)com_droidlogic_app_tv_TvControlManager_create_video_frame_bitmap
+ },
};
struct field {
- const char *class_name;
- const char *field_name;
- const char *field_type;
- jfieldID *jfield;
+ const char *class_name;
+ const char *field_name;
+ const char *field_type;
+ jfieldID *jfield;
};
static int find_fields(JNIEnv *env, field *fields, int count)
{
- for (int i = 0; i < count; i++) {
- field *f = &fields[i];
- jclass clazz = env->FindClass(f->class_name);
- if (clazz == NULL) {
- ALOGE("Can't find %s", f->class_name);
- return -1;
- }
-
- jfieldID field = env->GetFieldID(clazz, f->field_name, f->field_type);
- if (field == NULL) {
- ALOGE("Can't find %s.%s", f->class_name, f->field_name);
- return -1;
- }
-
- *(f->jfield) = field;
- }
-
- return 0;
+ for (int i = 0; i < count; i++) {
+ field *f = &fields[i];
+ jclass clazz = env->FindClass(f->class_name);
+ if (clazz == NULL) {
+ ALOGE("Can't find %s", f->class_name);
+ return -1;
+ }
+
+ jfieldID field = env->GetFieldID(clazz, f->field_name, f->field_type);
+ if (field == NULL) {
+ ALOGE("Can't find %s.%s", f->class_name, f->field_name);
+ return -1;
+ }
+
+ *(f->jfield) = field;
+ }
+
+ return 0;
}
// Get all the required offsets in java class and register native functions
int register_com_droidlogic_app_tv_TvControlManager(JNIEnv *env)
{
- field fields_to_find[] = {
- { "com/droidlogic/app/tv/TvControlManager", "mNativeContext", "I", &fields.context }
- };
+ field fields_to_find[] = {
+ { "com/droidlogic/app/tv/TvControlManager", "mNativeContext", "I", &fields.context }
+ };
- ALOGD("register_com_droidlogic_app_tv_TvControlManager.");
+ ALOGD("register_com_droidlogic_app_tv_TvControlManager.");
- if (find_fields(env, fields_to_find, NELEM(fields_to_find)) < 0)
- return -1;
+ if (find_fields(env, fields_to_find, NELEM(fields_to_find)) < 0)
+ return -1;
- jclass clazz = env->FindClass("com/droidlogic/app/tv/TvControlManager");
- fields.post_event = env->GetStaticMethodID(clazz, "postEventFromNative", "(Ljava/lang/Object;ILandroid/os/Parcel;)V");
- if (fields.post_event == NULL) {
- ALOGE("Can't find com/droidlogic/app/tv/TvControlManager.postEventFromNative");
- return -1;
- }
+ jclass clazz = env->FindClass("com/droidlogic/app/tv/TvControlManager");
+ fields.post_event = env->GetStaticMethodID(clazz, "postEventFromNative", "(Ljava/lang/Object;ILandroid/os/Parcel;)V");
+ if (fields.post_event == NULL) {
+ ALOGE("Can't find com/droidlogic/app/tv/TvControlManager.postEventFromNative");
+ return -1;
+ }
- // Register native functions
- return AndroidRuntime::registerNativeMethods(env, "com/droidlogic/app/tv/TvControlManager", camMethods, NELEM(camMethods));
+ // Register native functions
+ return AndroidRuntime::registerNativeMethods(env, "com/droidlogic/app/tv/TvControlManager", camMethods, NELEM(camMethods));
}
jint JNI_OnLoad(JavaVM *vm, void *reserved)
{
- JNIEnv *env = NULL;
- jint result = -1;
+ JNIEnv *env = NULL;
+ jint result = -1;
- if (vm->GetEnv((void **) &env, JNI_VERSION_1_4) != JNI_OK) {
- ALOGE("ERROR: GetEnv failed\n");
- goto bail;
- }
- assert(env != NULL);
+ if (vm->GetEnv((void **) &env, JNI_VERSION_1_4) != JNI_OK) {
+ ALOGE("ERROR: GetEnv failed\n");
+ goto bail;
+ }
+ assert(env != NULL);
- register_com_droidlogic_app_tv_TvControlManager(env);
+ register_com_droidlogic_app_tv_TvControlManager(env);
- /* success -- return valid version number */
- result = JNI_VERSION_1_4;
+ /* success -- return valid version number */
+ result = JNI_VERSION_1_4;
bail:
- return result;
+ return result;
}