4

アクティビティでアラームマネージャーを使用したい。このようなメインアクティビティのonPauseメソッドにアラームを設定しました。

Intent intent= new Intent(namaz_vakti_activity.this, namaz_vakti_activity.class);
PendingIntent sender = PendingIntent.getActivity(this, 1234567, intent,Intent.FLAG_ACTIVITY_NEW_TASK);

AlarmManager am = (AlarmManager) getSystemService(ALARM_SERVICE);
eltime=Calendar.getInstance().getTime().getHours()*60+Calendar.getInstance().getTime().getMinutes();
eltime=(long)(Sun_Rise*60)-eltime;
if (eltime<0) 
    eltime=eltime+24*60;
eltime=eltime-pre_time;
if (eltime<=0) 
    eltime=eltime+24*60;
if (uyandirma)
{
    am.set(AlarmManager.RTC_WAKEUP, Calendar.getInstance().getTimeInMillis()+eltime*60000, sender);
    Toast.makeText(this,"Uyandirma saati "+ConvertTime(Sun_Rise-pre_time/60.0),Toast.LENGTH_SHORT).show();
}
else
{
    am.cancel(sender);
}

namaz_vakti_activityが私の主な活動です。onPauseメソッドとonResumeメソッドはそれに属します。

また、onResumeメソッドでwakelockを使用して、スリープモードが発生しないようにします。

pm = (PowerManager)this.getSystemService(Context.POWER_SERVICE);
wl = pm.newWakeLock(PowerManager.FULL_WAKE_LOCK |PowerManager.ACQUIRE_CAUSES_WAKEUP | PowerManager.ON_AFTER_RELEASE,"namaz_vakti_activity");
wl.acquire();

コードの主な目的は、特定の時間にメインアクティビティ(namaz_vakti_activitiy)を再開することです。デバイスがスリープモードでない場合、コードは正常に機能します。ただし、スリープモードの場合はエラーが発生し、動作を停止します。解決策は単純だと思います。私はコードがわかりにくいです。

4

3 に答える 3

7

これで、以下のコードは完全に機能します。

  • アラームマネージャーはうまく機能します。ただし、画面には表示されないため、ウェイクロックを使用する必要があります
  • alarmmanager はデバイスを目覚めさせますが (その通りです、huang)、アクティビティはフォーカスを得ることができません。そのため、新しい行を定義する必要があります (Android 2.0 以降では次のフラグがサポートされています: getWindow().addFlags(WindowManager.LayoutParams.FLAG_DISMISS_KEYGUARD| WindowManager.LayoutParams.FLAG_TURN_SCREEN_ON);

要約されたコードは以下のとおりです。

public void onCreate(Bundle savedInstanceState)

...

    getWindow().addFlags(
        WindowManager.LayoutParams.FLAG_DISMISS_KEYGUARD|
        WindowManager.LayoutParams.FLAG_TURN_SCREEN_ON|
        WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);

...


protected void onResume()

    ...

//pm = (PowerManager)this.getSystemService(Context.POWER_SERVICE);
//wl = pm.newWakeLock(PowerManager.FULL_WAKE_LOCK,"namaz_vakti_activity");
//wl.acquire();

MPX=MediaPlayer.create(this, R.raw.azan1);

...

if (eltime==0 && uyandirma && !MPX.isPlaying())
{
    MPX.setVolume(1,1);
    MPX.start();
}


protected void onPause()

    ...

    Intent intent= new Intent(namaz_vakti_activity.this, namaz_vakti_activity.class);
    PendingIntent sender = PendingIntent.getActivity(this, 1234567, intent,Intent.FLAG_ACTIVITY_NEW_TASK);

    AlarmManager am = (AlarmManager) getSystemService(ALARM_SERVICE);
    eltime=Calendar.getInstance().getTime().getHours()*60+Calendar.getInstance().getTime().getMinutes();
    eltime=(long)(Sun_Rise*60)-eltime;
    if (eltime<0)
        eltime=eltime+24*60;
    eltime=eltime-pre_time;
    if (eltime<=0)
        eltime=eltime+24*60;
    if (uyandirma)
    {
        am.set(AlarmManager.RTC_WAKEUP, Calendar.getInstance().getTimeInMillis()+eltime*60000, sender);
        Toast.makeText(this,"Uyandirma saati "+ConvertTime(Sun_Rise-pre_time/60.0),Toast.LENGTH_SHORT).show();
    }
    else
    {
        am.cancel(sender);
    }

    if (MPX.isPlaying())
    {
        MPX.pause();
        MPX.release();
    }

    //if (wl.isHeld()) wl.release();
于 2011-03-19T17:15:49.840 に答える
2

私は同じ問題に直面していましたが、最も興味深いのは、Samsung Galaxy S duos では機能していましたが、Galaxy Nexus では機能していなかったことです。私の解決策は、ブロードキャストレシーバーの onReciever() メソッドで静的ロックを作成することでした。

private static PowerManager.WakeLock wakeLock;

public static void acquireWakeLock(Context ctx) {
    if (wakeLock != null)
        wakeLock.release();

    PowerManager pm = (PowerManager) ctx
            .getSystemService(Context.POWER_SERVICE);
    wakeLock = pm.newWakeLock(PowerManager.FULL_WAKE_LOCK
            | PowerManager.ACQUIRE_CAUSES_WAKEUP
            | PowerManager.ON_AFTER_RELEASE,
            "aqs_wake_lock");
    wakeLock.acquire();
}

public static void releaseWakeLock() {
    if (wakeLock != null)
        wakeLock.release();
    wakeLock = null;
}

startActivity() を呼び出す前に acquireWakeLock() を呼び出してから、起動されたアクティビティの OnCreate() メソッドで、少し遅れてアラーム音を鳴らしていました。 releaseWakeLock()。

new Handler().postDelayed(new Runnable() {

        @Override
        public void run() {
            playSound(getApplicationContext(), getAlarmUri());
        }
    }, 1000);

それが誰かに役立つことを願っています。

于 2013-07-04T20:41:03.053 に答える
2

あなたが使う

am.set(AlarmManager.RTC_WAKEUP, Calendar.getInstance().getTimeInMillis()+eltime*60000, sender); 

アラームを設定し、その中で AlarmManager.RTC_WAKEUP を使用しているため、開始しようとしているアクティビティは、デバイスがスリープ中でも起動されると思います。おそらく、ウェイクロックは必要ありません。

wakelock を使用する場合は、android.permission.WAKE_LOCK というパーミッションが必要です。これはあなたのコードの問題ですか?

于 2011-03-19T13:44:50.977 に答える