From 8435e6bd6c02aeb33db03e2c150453a84bdd268e Mon Sep 17 00:00:00 2001 From: Steve Slaven Date: Tue, 4 Jan 2011 15:20:04 -0800 Subject: Moved some constants and they key resolver out to a utility class diff --git a/src/net/hoopajoo/android/SoftKeys/K.java b/src/net/hoopajoo/android/SoftKeys/K.java new file mode 100644 index 0000000..8834e9c --- /dev/null +++ b/src/net/hoopajoo/android/SoftKeys/K.java @@ -0,0 +1,88 @@ +/* + * + * 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 . + * +*/ +package net.hoopajoo.android.SoftKeys; + +import java.io.File; +import java.io.FileOutputStream; +import java.util.ArrayList; +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; + +// Key constants and resolver maps +public class K { + public static String KEY_HOME = "home"; + public static String KEY_BACK = "back"; + public static String KEY_MENU = "menu"; + public static String KEY_SEARCH = "search"; + + public static int KEYID_HOME = 0; + public static int KEYID_BACK = 4; + public static int KEYID_MENU = 82; + public static int KEYID_SEARCH = 84; + + private static final Map mKeymap; + static { + Map t = new HashMap(); + t.put( KEY_BACK, KEYID_BACK ); + t.put( KEY_MENU, KEYID_MENU ); + t.put( KEY_SEARCH, KEYID_SEARCH ); + mKeymap = Collections.unmodifiableMap( t ); + } + + public static int keyNameToId( String n ) { + if( ! mKeymap.containsKey( n ) ) { + return 0; + } + return mKeymap.get( n ); + } +} diff --git a/src/net/hoopajoo/android/SoftKeys/SendInput.java b/src/net/hoopajoo/android/SoftKeys/SendInput.java index 9e962ad..aa30d62 100644 --- a/src/net/hoopajoo/android/SoftKeys/SendInput.java +++ b/src/net/hoopajoo/android/SoftKeys/SendInput.java @@ -61,16 +61,6 @@ import android.widget.Toast; public class SendInput extends Activity { public static String ACTION_CODE = "net.hoopajoo.android.SoftKeys.KEY_CODE"; - private static final Map mKeymap; - static { - Map t = new HashMap(); - 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) { @@ -95,15 +85,16 @@ public class SendInput extends Activity { return; }else{ // run through resolver - if( mKeymap.containsKey( key ) ) { - keyid = mKeymap.get( key ); - } + keyid = K.keyNameToId( key ); } }else if( e.getInt( "keyid", 0 ) != 0 ) { keyid = e.getInt( "keyid", 0 ); } + + if( keyid != 0 ) { + ((Globals)getApplication()).sendKeys( new int[] { keyid } ); + } - ((Globals)getApplication()).sendKeys( new int[] { keyid } ); // todo: make me a broadcast receiver.. or maybe this should be removed all together? // any good reasons to allow other apps to call hw keys? this.finish(); -- cgit v0.10.2