预定闹钟管理器在安卓系统中无法工作

5
我正在尝试启动一个每天在特定时间重复的闹钟服务。我在stackoverflow网站上查看了很多关于此问题的帖子,但没有成功。我按照一些教程操作: http://karanbalkar.com/2013/07/tutorial-41-using-alarmmanager-and-broadcastreceiver-in-android/http://javatechig.com/android/repeat-alarm-example-in-android 我的服务从未启动,我不明白原因。以下是我的代码:
我的清单文件:
     <uses-sdk
            android:minSdkVersion="8"
            android:targetSdkVersion="17" />

        <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
        <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
        <uses-permission android:name="android.permission.INTERNET"/>
        <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
        <uses-permission android:name="android.permission.WAKE_LOCK" />
        <uses-permission android:name="android.permission.CAMERA" />
        <uses-permission android:name="com.android.alarm.permission.SET_ALARM" />
<application>
        <service android:name="com.paper.DownloadService" android:enabled="true"/>
                  <receiver android:name="com.paper.MyReceiver" ></receiver>
</application>

我的接收器类:

public class MyReceiver extends BroadcastReceiver
{      
    @Override
    public void onReceive(Context rcontext, Intent intent)
    {
        Log.e("Main Activity", "inside on receive of myreceiver");
       Intent service1 = new Intent(rcontext, DownloadService.class);
       rcontext.startService(service1);

    }   
}

我的服务类:

 public class DownloadService extends Service {
    @Override
    public void onCreate() {
        // TODO Auto-generated method stub
        Log.e("Download Service", "CREATED");
    }   
    @SuppressLint({ "SimpleDateFormat", "NewApi" }) @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
        // TODO Auto-generated method stub

        Log.e("Download Service", "STARTED");
        return START_NOT_STICKY;
    }
 }

我的主要活动(在On Create方法中):

AlarmManager alarmManager = (AlarmManager) getSystemService(Context.ALARM_SERVICE);

            Calendar calendar = Calendar.getInstance();
            calendar.setTimeInMillis(System.currentTimeMillis());
            calendar.set(Calendar.HOUR_OF_DAY, 15);
            calendar.set(Calendar.MINUTE, 29);

             Intent myIntent = new Intent(this, MyReceiver.class);
             pendingIntent = PendingIntent.getBroadcast(this, 0, myIntent,0);

             alarmManager.setInexactRepeating(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(),
                     AlarmManager.INTERVAL_DAY, pendingIntent);

我正在尝试每天下午3:29设置我的闹钟,但该服务在那个时间或任何时间都没有启动。感谢您的帮助!


你设置了这个权限吗 <uses-permission android:name="com.android.alarm.permission.SET_ALARM" /> - Rohit Goswami
1
哦,你犯了一个错误...如果你使用的是Calendar.Hour,那么它会使用12小时制,或者如果你使用HOUR_OF_DAY,则使用24小时制...所以改为HOUR_OF_DAY...亲爱的,这样就可以了... - Rohit Goswami
@Devill:不,我的日志中没有显示“inside on receive of myreceiver”。我的手机时间是IST。日历毫秒数(14151):1425896922656和闹钟管理器间隔(14151):86400000。我将闹钟设置时间从14:29更改为14:59进行测试。 - Shreya
@RohitGoswami:我已经添加了该权限,但它仍然不起作用。 - Shreya
你想让你的服务每天在3:30或特定时间调用吗? - Piyush
显示剩余14条评论
2个回答

17

这是我为了使它工作所做的事情:

1)在我的清单文件中添加了<uses-permission android:name="com.android.alarm.permission.SET_ALARM"/>

2)更改了我的主要活动中的代码:

 AlarmManager alarmManager = (AlarmManager) getSystemService(Context.ALARM_SERVICE);

        Calendar calendar = Calendar.getInstance();
        calendar.set(Calendar.HOUR, 3);
        calendar.set(Calendar.MINUTE, 29);
        calendar.set(Calendar.AM_PM, Calendar.PM);

         Intent myIntent = new Intent(this, MyReceiver.class);
         pendingIntent = PendingIntent.getBroadcast(this, 0, myIntent,0);

         alarmManager.setInexactRepeating(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(),
                 AlarmManager.INTERVAL_DAY, pendingIntent);

希望这会对某人有所帮助!


12
仅当您需要使用setTime()方法设置系统墙上时钟时间时,才需要com.android.alarm.permission.SET_ALARM权限。详情请参考http://developer.android.com/reference/android/app/AlarmManager.html#setTime(long)。 - Nifhel
1
@Shreya。即使添加了该权限,它在我的情况下仍然无法工作。实际上,在Android 4.4及更低版本中根本不会触发。但是在Android > 4.4上,它确实会触发,但不会在预定时间触发。 - zulkarnain shah

0

主活动

public class MainActivity extends AppCompatActivity {
 @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Intent intent = new Intent(this, MyBroadcastReceiver.class);
        PendingIntent pendingIntent = PendingIntent.getBroadcast(this, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT);
        AlarmManager alarmManager = (AlarmManager) getSystemService(ALARM_SERVICE);
        alarmManager.set(AlarmManager.RTC_WAKEUP, System.currentTimeMillis()
                + (60 * 1000), pendingIntent); // 60 seconds after the current time
    }
}

警报接收器

public class MyBroadcastReceiver extends BroadcastReceiver {

    @Override
    public void onReceive(Context context, Intent intent) {

        
        Log.e("Testing","ok");

    }

}

清单文件

 <manifest xmlns:android="http://schemas.android.com/apk/res/android"
        package="com.testapp">
    
        <uses-permission android:name="android.permission.INTERNET" />
        <uses-permission android:name="android.permission.WAKE_LOCK" />
        <uses-permission android:name="android.permission.VIBRATE" />
        <uses-permission android:name="android.permission.REQUEST_IGNORE_BATTERY_OPTIMIZATIONS"/>
        <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">
                <intent-filter>
                    <action android:name="android.intent.action.MAIN" />
    
                    <category android:name="android.intent.category.LAUNCHER" />
                </intent-filter>
            </activity>
          
           <receiver android:name=".MyBroadcastReceiver" 
              android:enabled="true" />
        </application>
    
    </manifest>

为了后台工作,请在主活动中添加以下内容(如果应用程序已经移除,请将其从最近列表中删除)

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
            Intent intent = new Intent();
            String packageName = getPackageName();
            PowerManager pm = (PowerManager) getSystemService(Context.POWER_SERVICE);
            if (!pm.isIgnoringBatteryOptimizations(packageName)) {
                intent.setAction(Settings.ACTION_REQUEST_IGNORE_BATTERY_OPTIMIZATIONS);
                intent.setData(Uri.parse("package:" + packageName));
                startActivity(intent);
            }
        }

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接