2016-08-25 127 views
2

我想從我的Android磨損項目調用AlarmManager。但由於某些原因,它失敗了。以下是我的代碼相同。我確信我正在AlarmReceiver中調用setAlarm方法(我的日誌正在打印),但之後沒有任何反應。我的目標是每30秒發出一次警報。當AlarmReceiver onReceive被調用時。 SendBroadcast到我的服務,這反過來將消息發送到服務器。我在這裏做錯了什麼。AlarmManager不工作在Android Wear

清單詳細信息:

<uses-permission android:name="android.permission.WAKE_LOCK" /> 
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" /> 

在應用

<receiver android:name=".alarm.AlarmReceiver" /> 
     <receiver 
      android:name=".alarm.SampleBootReceiver" 
      android:enabled="false"> 
      <intent-filter> 
       <action android:name="android.intent.action.BOOT_COMPLETED" /> 
      </intent-filter> 
     </receiver> 

AlarmManager:

public class AlarmReceiver extends WakefulBroadcastReceiver { 

    private static final String TAG = "AlarmReceiver"; 

    // The app's AlarmManager, which provides access to the system alarm services. 
    private AlarmManager alarmMgr; 
    // The pending intent that is triggered when the alarm fires. 
    private PendingIntent alarmIntent; 

    @Override 
    public void onReceive(Context context, Intent intent) { 
     Log.d(TAG,"AlarmReceiver onReceive*******"); 
     Intent sensorIntent = new Intent("sensor"); 
     LocalBroadcastManager.getInstance(context).sendBroadcast(sensorIntent); 
    } 

    public void setAlarm(Context context) { 
     Log.d(TAG,"Alarm Manager started"); 
     alarmMgr = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE); 
     Intent intent = new Intent(context, AlarmReceiver.class); 
     alarmIntent = PendingIntent.getBroadcast(context, 0, intent, 0); 

     alarmMgr.setRepeating(AlarmManager.ELAPSED_REALTIME_WAKEUP, 
       System.currentTimeMillis()+1000,60000,alarmIntent); 

     ComponentName receiver = new ComponentName(context, SampleBootReceiver.class); 
     PackageManager pm = context.getPackageManager(); 

     pm.setComponentEnabledSetting(receiver, 
       PackageManager.COMPONENT_ENABLED_STATE_ENABLED, 
       PackageManager.DONT_KILL_APP); 

    } 
} 

SampleBootReceiver:

public class SampleBootReceiver extends BroadcastReceiver { 
    AlarmReceiver alarm = new AlarmReceiver(); 
    @Override 
    public void onReceive(Context context, Intent intent) { 
     if (intent.getAction().equals("android.intent.action.BOOT_COMPLETED")) 
     { 
      alarm.setAlarm(context); 
     } 
    } 
} 

回答

0

您可能需要檢查Creating and Running a Wearable AppPackaging Wearable Apps以確保您可以將掌上電腦與佩戴設備配對。

在穿戴發展中,手持設備和可穿戴設備之間的正確通信/配對對發送和接收消息很重要。利用MessageApi,發送消息給穿戴者開始一項活動。要收到收到的消息的通知,請執行MessageListener接口以提供消息事件的偵聽器。

你也可以看到我的回答here和另一個相關的SO問題here。這裏還有關於Wearable NotificationAndroid Wear Development的教程。

希望它有幫助!

+0

我的android Wear應用程序和移動應用程序沒有任何問題來回發送消息。我需要將我從手錶發送的信息發送到手機。爲了計時,目前我正在使用Handler.postDelayed,它工作得很好,但是我想要一直髮送消息,即使CPU進入睡眠狀態。所以我選擇了這個。 – praneel

0

從API級別19開始報警傳送並不精確:操作系統將切換報警以最大限度地減少喚醒和電池使用。

這在低功耗模式下的可穿戴設備上尤其如此。

爲了保證交付使用setExactAndAllowWhileIdle

setExact(int, long, PendingIntent),但這個報警將被允許執行,即使系統處於低功耗空閒模式。如果您不需要精確安排報警,但仍然需要在空閒時執行,請考慮使用setAndAllowWhileIdle(int, long, PendingIntent)