diff options
Diffstat (limited to 'src/net/hoopajoo/android/SoftKeys/SendInput.java')
-rw-r--r-- | src/net/hoopajoo/android/SoftKeys/SendInput.java | 109 |
1 files changed, 109 insertions, 0 deletions
diff --git a/src/net/hoopajoo/android/SoftKeys/SendInput.java b/src/net/hoopajoo/android/SoftKeys/SendInput.java new file mode 100644 index 0000000..9037e82 --- /dev/null +++ b/src/net/hoopajoo/android/SoftKeys/SendInput.java @@ -0,0 +1,109 @@ +/* + * + * Copyright (c) 2010 Steve Slaven + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + * +*/ +package net.hoopajoo.android.SoftKeys; + +import java.io.File; +import java.io.FileOutputStream; +import java.util.Collections; +import java.util.HashMap; +import java.util.Iterator; +import java.util.List; +import java.util.Map; + +import android.app.Activity; +import android.app.Notification; +import android.app.NotificationManager; +import android.app.PendingIntent; +import android.content.Context; +import android.content.Intent; +import android.content.SharedPreferences; +import android.content.pm.PackageInfo; +import android.content.pm.PackageManager; +import android.content.pm.ResolveInfo; +import android.graphics.drawable.BitmapDrawable; +import android.graphics.drawable.Drawable; +import android.net.Uri; +import android.os.Bundle; +import android.os.Handler; +import android.preference.PreferenceManager; +import android.util.Log; +import android.view.KeyEvent; +import android.view.Menu; +import android.view.MenuInflater; +import android.view.MenuItem; +import android.view.View; +import android.view.ViewGroup; +import android.view.WindowManager; +import android.view.View.OnClickListener; +import android.view.View.OnLongClickListener; +import android.view.View.OnTouchListener; +import android.widget.ImageButton; +import android.widget.RemoteViews; +import android.widget.Toast; + +// this is just a stub to handle intent calls +public class SendInput extends Activity { + public static String ACTION_CODE = "net.hoopajoo.android.SoftKeys.KEY_CODE"; + + private static final Map<String,Integer> mKeymap; + static { + Map<String,Integer> t = new HashMap<String,Integer>(); + t.put( "back", 4 ); + t.put( "menu", 82 ); + t.put( "search", 84 ); + mKeymap = Collections.unmodifiableMap( t ); + } + + + /** Called when the activity is first created. */ + @Override + public void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + onNewIntent( getIntent() ); + } + + @Override + public void onNewIntent( Intent i ) { + Globals app = (Globals)getApplication(); + + String action = i.getAction(); + if( action.equals( ACTION_CODE ) ) { + // by key name? + int keyid = 0; + Bundle e = i.getExtras(); + boolean longClick = e.getBoolean( "longclick", false ); + if( e.getString( "keyname" ) != null ) { + String key = e.getString( "keyname" ); + if( key.equals( "home" ) ) { + ((Globals)getApplication()).doHomeAction( longClick ); + return; + }else{ + // run through resolver + if( mKeymap.containsKey( key ) ) { + keyid = mKeymap.get( key ); + } + } + } + + ((Globals)getApplication()).sendKeys( new int[] { keyid } ); + // todo: make me a broadcast receiver + this.finish(); + } + } +} |