2016-08-25 9 views
2

Android wearプロジェクトからAlarmManagerを呼び出そうとしています。しかし、何らかの理由でその失敗。以下は私のコードです。私はAlarmReceiver(私のログは印刷されています)でsetAlarmメソッドを呼び出していると確信していますが、その後は何も起こりません。私の目標は、30秒ごとにアラームを実行しています。 AlarmReceiver onReceiveが呼び出されたとき。私のサービスにSendBroadcastを送信し、サーバーにメッセージを送信します。私はここで間違って何をしていますか?AndroidウェアでAlarmManagerが動作しない

マニフェスト詳細:

アプリケーション内
<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と別の関連する質問hereを見ることができます。 Wearable NotificationAndroid Wear Developmentのチュートリアルもあります。

希望すると助かります!

+0

アンドロイドウェアアプリとモバイルアプリでは、メッセージのやりとりに問題はありません。私は時計から電話に送るメッセージを時間をかける必要があります。タイミングに関しては、現在、私はHandler.postDelayedを使用していますが、問題なく動作しますが、CPUがスリープ状態になっても常にメッセージを送信したいと思います。だから私はこれを選んだ。 – praneel

0

APIレベル19から始まるアラーム配信は不正確です:OSは、起床とバッテリの使用を最小限に抑えるためにアラームを移動します。

これは特に、低消費電力モードのウェアラブルデバイスに当てはまります。

は配信使用 setExact(int, long, PendingIntent)同様 setExactAndAllowWhileIdle

保証するために、しかし、このシステムは、低消費電力アイドルモードにあるときでも、このアラームは実行を許可されます。アラームの正確なスケジューリングは必要ありませんが、アイドル状態で実行する必要がある場合は、setAndAllowWhileIdle(int, long, PendingIntent)の使用を検討してください。

関連する問題