diff options
author | mauimauer <sebastian@n-unity.de> | 2012-02-17 13:30:04 +0100 |
---|---|---|
committer | mauimauer <sebastian@n-unity.de> | 2012-02-17 13:30:04 +0100 |
commit | dc27c42df6c819a816660e86060d4dfa14c9f217 (patch) | |
tree | 9199ec864fdd64d07a3f1968af0a0b02c0f29c5e /tvout/src | |
parent | 72114c1c1583d3834c66b0e28cfe9999d9fd00ba (diff) | |
download | device_samsung_n7000-dc27c42df6c819a816660e86060d4dfa14c9f217.zip device_samsung_n7000-dc27c42df6c819a816660e86060d4dfa14c9f217.tar.gz device_samsung_n7000-dc27c42df6c819a816660e86060d4dfa14c9f217.tar.bz2 |
Updated stuff for I9220ZSLP1
Diffstat (limited to 'tvout/src')
-rw-r--r-- | tvout/src/android/hardware/Tvout.java | 102 | ||||
-rw-r--r-- | tvout/src/com/teamhacksung/tvout/BootCompletedReceiver.java | 12 | ||||
-rw-r--r-- | tvout/src/com/teamhacksung/tvout/TvOutService.java | 116 |
3 files changed, 230 insertions, 0 deletions
diff --git a/tvout/src/android/hardware/Tvout.java b/tvout/src/android/hardware/Tvout.java new file mode 100644 index 0000000..f2fc3a8 --- /dev/null +++ b/tvout/src/android/hardware/Tvout.java @@ -0,0 +1,102 @@ +package android.hardware; + +import android.util.Log; + +public class Tvout { + private static final String TAG = "Tvout_java"; + + static { + System.loadLibrary("tvout_jni"); + } + + public Tvout() { + Log.i(TAG, "Tvout Initializing"); + _native_setup(); + } + + private native boolean _TvoutGetCableStatus(); + + private native boolean _TvoutGetStatus(); + + private native boolean _TvoutGetSubtitleStatus(); + + private native boolean _TvoutGetSuspendStatus(); + + private native boolean _TvoutPostSubtitle(String string, int param); + + private native boolean _TvoutPostSuspend(String string); + + private native boolean _TvoutSetCableStatus(boolean connected); + + private native boolean _TvoutSetOutputMode(int mode); + + private native boolean _TvoutSetResolution(int resolution); + + private native boolean _TvoutSetStatus(boolean enabled); + + private native boolean _TvoutSetSubtitleStatus(boolean enabled); + + private native boolean _TvoutSetSuspendStatus(boolean enabled); + + private native boolean _TvoutSetDefaultString(String string); + + private final native void _native_setup(); + + private final native void _release(); + + public boolean getCableStatus() { + return _TvoutGetCableStatus(); + } + + public boolean getStatus() { + return _TvoutGetStatus(); + } + + public boolean getSubtitleStatus() { + return _TvoutGetSubtitleStatus(); + } + + public boolean getSuspendStatus() { + return _TvoutGetSuspendStatus(); + } + + public boolean postSubtitle(String string, int paramInt) { + return _TvoutPostSubtitle(string, paramInt); + } + + public boolean postSuspend(String string) { + return _TvoutPostSuspend(string); + } + + public boolean setCableStatus(boolean connected) { + return _TvoutSetCableStatus(connected); + } + + public boolean setOutputMode(int mode) { + return _TvoutSetOutputMode(mode); + } + + public boolean setResolution(int resolution) { + return _TvoutSetResolution(resolution); + } + + public boolean setStatus(boolean enabled) { + return _TvoutSetStatus(enabled); + } + + public boolean setSubtitleStatus(boolean enabled) { + return _TvoutSetSubtitleStatus(enabled); + } + + public boolean setSuspendStatus(boolean enabled) { + return _TvoutSetSuspendStatus(enabled); + } + + public boolean setDefaultString(String string) { + return _TvoutSetDefaultString(string); + } + + public void release() { + _release(); + } +} diff --git a/tvout/src/com/teamhacksung/tvout/BootCompletedReceiver.java b/tvout/src/com/teamhacksung/tvout/BootCompletedReceiver.java new file mode 100644 index 0000000..5ed6af6 --- /dev/null +++ b/tvout/src/com/teamhacksung/tvout/BootCompletedReceiver.java @@ -0,0 +1,12 @@ +package com.teamhacksung.tvout; + +import android.content.BroadcastReceiver; +import android.content.Context; +import android.content.Intent; + +public class BootCompletedReceiver extends BroadcastReceiver { + @Override + public void onReceive(Context context, Intent intent) { + context.startService(new Intent(context, TvOutService.class)); + } +} diff --git a/tvout/src/com/teamhacksung/tvout/TvOutService.java b/tvout/src/com/teamhacksung/tvout/TvOutService.java new file mode 100644 index 0000000..b633b3d --- /dev/null +++ b/tvout/src/com/teamhacksung/tvout/TvOutService.java @@ -0,0 +1,116 @@ +package com.teamhacksung.tvout; + +import android.app.Service; +import android.content.BroadcastReceiver; +import android.content.Context; +import android.content.Intent; +import android.content.IntentFilter; +import android.hardware.Tvout; +import android.nfc.Tag; +import android.os.IBinder; +import android.os.RemoteException; +import android.os.ServiceManager; +import android.util.Log; + +public class TvOutService extends Service { + + public static final String TAG = "TvOutService_java"; + + private Tvout mTvOut; + private boolean mWasOn = false; // For enabling on screen on + + private BroadcastReceiver mReceiver = new BroadcastReceiver() { + @Override + public void onReceive(Context context, Intent intent) { + String action = intent.getAction(); + if (Intent.ACTION_HDMI_AUDIO_PLUG.equals(action)) { + getTvoutInstance(); + int state = intent.getIntExtra("state", 0); + if (state == 1 && !mTvOut.getStatus()) { + // Enable when cable is plugged + Log.i(TAG, "HDMI plugged"); + mWasOn = false; + enable(); + } else if (mTvOut.getStatus()) { + // Disable when cable is unplugged + Log.i(TAG, "HDMI unplugged"); + mWasOn = false; + disable(); + releaseTvout(); + } + } else if (Intent.ACTION_SCREEN_ON.equals(action)) { + if (mTvOut != null && mWasOn) { + Log.i(TAG, "Screen On - Resume TvOut stream"); + mWasOn = false; + mTvOut.setSuspendStatus(false); + } + } else if (Intent.ACTION_SCREEN_OFF.equals(action)) { + if (mTvOut != null && mTvOut.getStatus()) { + Log.i(TAG, "Screen Off - Pausing TvOut stream"); + mWasOn = true; + mTvOut.setSuspendStatus(true); + } + } + } + + }; + + @Override + public IBinder onBind(Intent intent) { + return null; + } + + @Override + public void onCreate() { + IntentFilter filter = new IntentFilter(Intent.ACTION_HDMI_AUDIO_PLUG); + filter.addAction(Intent.ACTION_SCREEN_OFF); + filter.addAction(Intent.ACTION_SCREEN_ON); + registerReceiver(mReceiver, filter); + Log.i(TAG, "Registered Receiver"); + } + + @Override + public int onStartCommand(Intent intent, int flags, int startId) { + return START_STICKY; + } + + private boolean getTvoutInstance() { + if (mTvOut != null) return true; + + try { + mTvOut = new Tvout(); + } catch (Exception e) { + return false; + } + + return true; + } + + private void releaseTvout() { + if (mTvOut != null) { + mTvOut.release(); + mTvOut = null; + } + } + + @Override + public void onDestroy() { + unregisterReceiver(mReceiver); + releaseTvout(); + super.onDestroy(); + } + + private void enable() { + if (mTvOut == null) return; + mTvOut.setStatus(true); + mTvOut.setCableStatus(true); + mTvOut.setSuspendStatus(false); + } + + private void disable() { + if (mTvOut == null) return; + mTvOut.setStatus(false); + mTvOut.setCableStatus(false); + } + +} |