From 3278b55819b308779ffed838300f25f011ffe2e3 Mon Sep 17 00:00:00 2001 From: Eric House Date: Sun, 17 Nov 2013 21:21:06 -0800 Subject: [PATCH] return whether NFC *can* be enabled as well as whether it is --- .../org/eehouse/android/xw4/DlgDelegate.java | 4 +-- .../src/org/eehouse/android/xw4/NFCUtils.java | 30 ++++++++++++++----- 2 files changed, 24 insertions(+), 10 deletions(-) diff --git a/xwords4/android/XWords4/src/org/eehouse/android/xw4/DlgDelegate.java b/xwords4/android/XWords4/src/org/eehouse/android/xw4/DlgDelegate.java index 1259826d0..43368f20a 100644 --- a/xwords4/android/XWords4/src/org/eehouse/android/xw4/DlgDelegate.java +++ b/xwords4/android/XWords4/src/org/eehouse/android/xw4/DlgDelegate.java @@ -229,7 +229,7 @@ public class DlgDelegate { public void showInviteChoicesThen( final int callbackID ) { if ( Utils.deviceSupportsSMS( m_activity ) - || NFCUtils.nfcAvail( m_activity ) ) { + || NFCUtils.nfcAvail( m_activity )[1] ) { DlgState state = new DlgState( INVITE_CHOICES_THEN, callbackID ); addState( state ); m_activity.showDialog( INVITE_CHOICES_THEN ); @@ -415,7 +415,7 @@ public class DlgDelegate { OnClickListener lstnr = mkCallbackClickListener( state ); boolean haveSMS = Utils.deviceSupportsSMS( m_activity ); - boolean haveNFC = NFCUtils.nfcAvail( m_activity ); + boolean haveNFC = NFCUtils.nfcAvail( m_activity )[1]; int msgID; if ( haveSMS && haveNFC ) { msgID = R.string.nfc_or_sms_or_email; diff --git a/xwords4/android/XWords4/src/org/eehouse/android/xw4/NFCUtils.java b/xwords4/android/XWords4/src/org/eehouse/android/xw4/NFCUtils.java index 54be61c25..41981bcaf 100644 --- a/xwords4/android/XWords4/src/org/eehouse/android/xw4/NFCUtils.java +++ b/xwords4/android/XWords4/src/org/eehouse/android/xw4/NFCUtils.java @@ -39,6 +39,7 @@ public class NFCUtils { } private static boolean s_inSDK; + private static boolean[] s_nfcAvail; private static SafeNFC s_safeNFC; static { s_inSDK = 14 <= Integer.valueOf( android.os.Build.VERSION.SDK ); @@ -75,16 +76,21 @@ public class NFCUtils { } } - public static boolean nfcAvail( Context context ) + // Return array of two booleans, the first indicating whether the + // device supports NFC and the second whether it's on. Only the + // second can change. + public static boolean[] nfcAvail( Context context ) { - boolean result = s_inSDK; - if ( result ) { - NfcManager manager = - (NfcManager)context.getSystemService( Context.NFC_SERVICE ); - NfcAdapter adapter = manager.getDefaultAdapter(); - result = null != adapter && adapter.isEnabled(); + if ( null == s_nfcAvail ) { + s_nfcAvail = new boolean[] { + s_inSDK && null != getNFCAdapter( context ), + false + }; } - return result; + if ( s_nfcAvail[0] ) { + s_nfcAvail[1] = getNFCAdapter( context ).isEnabled(); + } + return s_nfcAvail; } public static String getFromIntent( Intent intent ) @@ -122,4 +128,12 @@ public class NFCUtils { }); return msg; } + + private static NfcAdapter getNFCAdapter( Context context ) + { + NfcManager manager = + (NfcManager)context.getSystemService( Context.NFC_SERVICE ); + return manager.getDefaultAdapter(); + } + }