| /* |
| * Copyright (C) 2010 The Android Open Source Project |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| package android.nfc; |
| |
| import android.annotation.SystemService; |
| import android.compat.annotation.UnsupportedAppUsage; |
| import android.content.Context; |
| import android.os.Build; |
| |
| /** |
| * High level manager used to obtain an instance of an {@link NfcAdapter}. |
| * <p> |
| * Use {@link android.content.Context#getSystemService(java.lang.String)} |
| * with {@link Context#NFC_SERVICE} to create an {@link NfcManager}, |
| * then call {@link #getDefaultAdapter} to obtain the {@link NfcAdapter}. |
| * <p> |
| * Alternately, you can just call the static helper |
| * {@link NfcAdapter#getDefaultAdapter(android.content.Context)}. |
| * |
| * <div class="special reference"> |
| * <h3>Developer Guides</h3> |
| * <p>For more information about using NFC, read the |
| * <a href="{@docRoot}guide/topics/nfc/index.html">Near Field Communication</a> developer guide.</p> |
| * </div> |
| * |
| * @see NfcAdapter#getDefaultAdapter(android.content.Context) |
| */ |
| @SystemService(Context.NFC_SERVICE) |
| public final class NfcManager { |
| private final NfcAdapter mAdapter; |
| |
| /** |
| * @hide |
| */ |
| @UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.P, trackingBug = 115609023) |
| public NfcManager(Context context) { |
| NfcAdapter adapter; |
| context = context.getApplicationContext(); |
| if (context == null) { |
| throw new IllegalArgumentException( |
| "context not associated with any application (using a mock context?)"); |
| } |
| try { |
| adapter = NfcAdapter.getNfcAdapter(context); |
| } catch (UnsupportedOperationException e) { |
| adapter = null; |
| } |
| mAdapter = adapter; |
| } |
| |
| /** |
| * Get the default NFC Adapter for this device. |
| * |
| * @return the default NFC Adapter |
| */ |
| public NfcAdapter getDefaultAdapter() { |
| return mAdapter; |
| } |
| } |