在背景中对Eddystone Beacon作出反应

时间:2017-03-22 18:55:12

标签: java android beacon eddystone

我基本上尝试使用提供的第一个答案来完成this。这个问题有关于网络和SO的答案,但我无法让它发挥作用。是否有我需要启用的东西,添加到我的清单等等?我想对手机范围内的灯塔做出反应。我在Android Studio中工作,定位到Android 4.3并使用Android Beacon Library。根据他们的文档,我所需要的只是实现BootstrapNotifier,设置Region,然后只要它扫描信标,它就会自动调用didEnterRegion。我的区域是Region region = new Region("all-beacons-region", null, null, null);

我还构建了一个非常简单的应用程序,它可以扫描并找到前景中的信标。所以没有问题,我绝对能够拿起我的信标并从中获取基本信息。

我的主要活动如下:

package com.example.justin.backgroundscantest;

    import android.support.v7.app.AppCompatActivity;
    import android.os.Bundle;

    public class MainActivity extends AppCompatActivity {

        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
        }
    }

我的班级看起来像这样:

import android.app.Application;
import android.content.Intent;
import android.util.Log;

import com.example.justin.backgroundscantest.MainActivity;

import org.altbeacon.beacon.startup.BootstrapNotifier;
import org.altbeacon.beacon.startup.RegionBootstrap;

import org.altbeacon.beacon.BeaconManager;
import org.altbeacon.beacon.BeaconParser;
import org.altbeacon.beacon.Region;

public class TestApp extends Application implements BootstrapNotifier {
    private static final String TAG = ".TestApp";
    private RegionBootstrap regionBootstrap;

    @Override
    public void onCreate() {
        super.onCreate();
        Log.d(TAG, "App started up");
        BeaconManager beaconManager = BeaconManager.getInstanceForApplication(this);
        beaconManager.getBeaconParsers().add(new BeaconParser().setBeaconLayout("s:0-1=feaa,m:2-2=00,p:3-3:-41,i:4-13,i:14-19"));

        // wake up the app when any beacon is seen (you can specify specific id filers in the parameters below)
        Region region = new Region("com.example.myapp.boostrapRegion", null, null, null);
        regionBootstrap = new RegionBootstrap(this, region);
    }

    @Override
    public void didEnterRegion(Region arg0) {
        Log.d(TAG, "Got a didEnterRegion call");
        // This call to disable will make it so the activity below only gets launched the first time a beacon is seen (until the next time the app is launched)
        // if you want the Activity to launch every single time beacons come into view, remove this call.
        regionBootstrap.disable();
        Intent intent = new Intent(this, MainActivity.class);
        // IMPORTANT: in the AndroidManifest.xml definition of this activity, you must set android:launchMode="singleInstance" or you will get two instances
        // created when a user launches the activity manually and it gets launched from here.
        intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
        this.startActivity(intent);
    }
}

(编辑) 最后,AndroidManifest.xml:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.justin.backgroundscantest">

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>


</manifest>

这一切都很简单,如果我错过了一些简单或愚蠢的东西,我很好奇。我在网络上的几个地方找到了这个例子,但没有提到我可能错过的任何内容。我有一个非常扎实的编码背景,但我是Android的新手,也是Eddystone / BLE技术的新手。并且只是为了澄清实际问题:当我在信标范围内移动手机时,我的应用程序没有任何反应。我的期望是它会“醒来”并开始使用MainActivity。我绝对是在灯塔的范围内,灯塔肯定在,再次,我能够在前景扫描它。它只是不会唤醒我的应用程序。谢谢!

1 个答案:

答案 0 :(得分:1)

创建自定义Android ApplicationTestApp时,您必须在清单中使用name属性声明它。像这样:

<application
    android:name="TestApp"
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:supportsRtl="true"
    android:theme="@style/AppTheme">

如果您不这样做,Android将不会使用您的自定义TestApp类,而是默认使用其内置的基础Application类,而不会导致TestApp代码被执行。