我知道有很多这样的问题,但没有一个解决方案对我有帮助。我尝试使用AlarmManager安排BroadcastReciever。现在,它应该做的就是做一个Toast并写一些文件。 这是我的代码,我既没有吐司也没有#34;闹钟"也没有创建日志文件。 显示了Mainactivity的Toast。任何想法?
这是清单,
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.android.alarmtest" >
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="com.android.alarm.permission.SET_ALARM"/>
<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"
android:label="@string/app_name"
android:theme="@style/AppTheme.NoActionBar" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<receiver android:name=".AlarmReciever"/>
<service android:enabled="true" android:name=".MyService" />
</application>
</manifest>
MainActivity
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
long time = new GregorianCalendar(2015,12,4,9,44).getTimeInMillis();
Intent intentAlarm = new Intent(this, AlarmReciever.class);
intentAlarm.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
AlarmManager alarmManager = (AlarmManager) getSystemService(Context.ALARM_SERVICE);
alarmManager.set(AlarmManager.RTC_WAKEUP,time, PendingIntent.getBroadcast(this,1, intentAlarm, PendingIntent.FLAG_UPDATE_CURRENT));
Toast.makeText(this, "Alarm Scheduled", Toast.LENGTH_LONG).show();
}
}
和接收者
public class AlarmReciever extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
Toast.makeText(context,"alarm",Toast.LENGTH_LONG);
log("alarm");
}
public void log(String s) {
Log.e("STATE", s);
File f = new File(Environment.getExternalStorageDirectory(),"log.txt");
try {
if (!f.exists()) f.createNewFile();
FileWriter fileWriter = new FileWriter(f, true);
fileWriter.write(s+"\n");
fileWriter.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
答案 0 :(得分:1)
来自Docs:注意:从API 19开始,传递给此方法的触发时间被视为不精确:警报将不会在此时间之前传递,但可能会延迟并在稍后传递。操作系统将使用此策略以便批量处理&#34;在整个系统中一起报警,最大限度地减少设备需要“唤醒”的次数。并尽量减少电池使用。一般而言,只要将来安排的警报很长,就不会推迟在不久的将来安排的警报。
targetSdkVersion在API 19之前的应用程序将继续获得之前的警报行为:所有计划的警报都将被视为完全警告。
所以Hiren Patel在他的回答中说过,对你有用。
请告诉我们有关您的测试环境的更多信息。
答案 1 :(得分:1)
int trigger_time= System.currentTimeMillis() + 30 * 1000;
if(Build.VERSION.SDK_INT >= 19) {
alarmManager.setExact(AlarmManager.RTC_WAKEUP, trigger_time, pendingIntent);
} else {
alarmManager.set(AlarmManager.RTC_WAKEUP, trigger_time, pendingIntent);
}
修改强>
setRepeating 与 setInexactRepeating 之间的差异:
确定警报需要的准确程度
选择警报类型通常是创建警报的第一步。另一个区别是你需要警报的准确程度。
对于大多数应用,setInexactRepeating()
是正确的选择。当您使用此方法时, Android会同步多个不准确的重复警报并同时触发它们。这会减少电池上的消耗。< / p>
对于以时间要求严格的罕见应用为例,闹钟需要每天中午12:00 精确,然后使用setRepeating()
。< / p>
希望这会对你有所帮助。