我的BroadcastReceiver不会打电话

苏海尔

我在致电我的BroadcastReceiver时遇到问题。我不知道问题在哪里。这是我的代码Myalarm.class,它会自动调用BroadcastReceiver(AlarmReceiver)。我在广播中做了一些标记,看他是否打过电话。

MyAlarm.class

public class MyAlarm extends SherlockFragmentActivity implements OnClickListener {
    TextView textAlarmPrompt;
    public static final int NOTIFICATION_ID = 42;
    private String notificationTitle;
    TimePickerDialog timePickerDialog;
    final static int RQS_1 = 1;
    String ID_Alerte;
    long alarm_GPS;
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.myalarm);
        ((Button)this.findViewById(R.id.annuler)).setOnClickListener(this);
        Intent i = getIntent();
        Bundle myBundle= i.getExtras();
        alarm_GPS = myBundle.getLong("alarm_gps");
        ID_Alerte = myBundle.getString("id_alerte"); 
        //  openTimePickerDialog(false);

        ///////////// call AlarmReceiver//////////////:
        AlarmManager am=(AlarmManager)this.getSystemService(Context.ALARM_SERVICE);
        Intent intentlocalisation = new Intent(this,AlarmReceiver.class);
        //put data to BroadcastReceiver 
        intentlocalisation.putExtra("id_alerte", ID_Alerte);
        PendingIntent pi = PendingIntent.getBroadcast(this, 0, intentlocalisation, 0);
        am.setRepeating(AlarmManager.RTC_WAKEUP, System.currentTimeMillis()+3000, alarm_GPS , pi); 

    }

    @Override
    public void onClick(View v) {
        // TODO Auto-generated method stub
        switch(v.getId()){
        case R.id.annuler:
        /////////   Alarm SMS cancel (AlarmReceiver)  //////////
            Intent intent_stopsms = new Intent(this, AlarmReceiver.class);
            PendingIntent sendersms = PendingIntent.getBroadcast(getBaseContext(), RQS_1, intent_stopsms, 0);
            AlarmManager alarmManagersms = (AlarmManager) this.getSystemService(Context.ALARM_SERVICE);
            alarmManagersms.cancel(sendersms);
            Toast.makeText(this, "Cancelled alarm sms", Toast.LENGTH_SHORT).show();

            Intent adv=new Intent(MyAlarm.this,
                    Home.class);
            startActivity(adv);
            finish();
            break;
        }
    }
}

这是我的AlarmReceiver:

public class AlarmReceiver extends BroadcastReceiver {
    String ID_Alerte;
    @Override
    public void onReceive(Context arg0, Intent arg1) {
        arg0.stopService(new Intent(arg0, MyService.class));
        ///////////////////////////
        Log.i("Alarm Receiver","My receive is shown up");
        ID_Alerte=arg1.getStringExtra("id_alerte");
        Toast.makeText(arg0, "Alarm received!id_alerte=" +ID_Alerte , Toast.LENGTH_LONG).show();
        //////////////////////////////////
        Intent serviceIntent = new Intent(arg0,MyService.class);
        serviceIntent.putExtra("id_alerte", ID_Alerte);
        arg0.startService(serviceIntent);
    }
}

这是我的Manifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.my_app"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="18" />

    <uses-feature
        android:glEsVersion="0x00020000"
        android:required="false" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/icon_logo"
        android:label="@string/app_name"
        android:theme="@style/Theme.SherlockCustom" >
        <activity
            android:name="com.example.my_app.MainActivity"
            android:label="@string/app_name"
            android:screenOrientation="portrait" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name=".MonProfile" />
        <activity android:name=".Register" />
        <activity android:name=".Home" />
        <activity android:name=".Home1" />
        <activity android:name=".Activity3" />
        <activity android:name=".MyAlarm" />
        <activity android:name=".JSONParsingAlertes" />
        <activity android:name=".JSONParsingProches" />
        <activity android:name=".Profil_Proche" />
        <activity android:name=".Nouveau_Proche" />
        <activity android:name=".Modifier_Proche" />
        <activity android:name=".detailAlert" />
        <activity android:name=".About" />
        <activity android:name=".Code_Request" />
        <activity
            android:name=".Authentification"
            android:screenOrientation="portrait" />
        <activity
            android:name=".Advanced"
            android:screenOrientation="portrait" />
        <activity
            android:name=".Tracer"
            android:screenOrientation="portrait" />
        <activity android:name=".LegalNoticesActivity" />
        <activity
            android:name=".ActivityNotification"
            android:label="@string/app_name" />

        <service android:name=".NotificationService" />
        <service android:name=".GetProche" />
        <service android:name=".MyService" >
        </service>

        <receiver
            android:name="com.example.my_app.AlarmReceiver"
            android:exported="true" />


        <meta-data
            android:name="com.google.android.maps.v2.API_KEY"
            android:value="*************************" />
    </application>

    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.VIBRATE" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission android:name="com.google.android.providers.gsf.permission.READ_GSERVICES" />
    <uses-permission android:name="com.example.my_app.permission.MAPS_RECEIVE" />

</manifest>

PS:对不起,如果我的英语不好

克里斯托弗

我想这是行不通的,因为您的接收者声明缺少此intent-filter部分:

<receiver android:name="com.example.my_app.AlarmReceiver">
<intent-filter>
   <action android:name="com.example.my_app.MyAlarm.FIRE_ALARM" />
</intent-filter>
</receiver>

然后当然,您必须通过来为您在MyAlarm课堂上的意图设定动作intent.setAction("com.example.my_app.MyAlarm.FIRE_ALARM")在此处阅读更多信息:http : //developer.android.com/guide/components/intents-filters.html

 ///////////// call AlarmReceiver//////////////:
    AlarmManager am=(AlarmManager)this.getSystemService(Context.ALARM_SERVICE);
    Intent intentlocalisation = new Intent(this,AlarmReceiver.class);
    //put data to BroadcastReceiver 
    intentlocalisation.putExtra("id_alerte", ID_Alerte);
    Intentlocalisation.setAction("com.example.my_app.MyAlarm.FIRE_ALARM")        PendingIntent pi = PendingIntent.getBroadcast(this, 0, intentlocalisation, 0);
    am.setRepeating(AlarmManager.RTC_WAKEUP, System.currentTimeMillis()+3000, alarm_GPS , pi); 

}

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

为什么我越来越流<OBJECT>当我打电话后付费的流()()?

我打电话的EntityManager的NullReferenceException

没有一个回应时,我打电话给我的web服务的GET请求

谁在打电话给我的HttpServletRequest?

打电话给iOS Xamarin

我拨打电话的功能出了什么问题

为什么我们不能打电话给setTimeout申请?

RxJava,如果我不打电话给处置怎么办?

如果快速拨打电话,Android LiveData Observable不会返回数据

在Unity中打电话?

为什么我不能直接打电话给减速机?

当我打电话给Xajax时RewriteRule得到错误

MVC从我打电话给Json结果到同一视图

我应该在哪里打电话给setintreval

不会让我在课外打电话

我可以通过我的应用程序(Flutter Android和IOS)直接拨打电话吗?

借位检查器不会让我打电话给setter之后再打电话给getter

从Angular给我的.NET Core团队打电话

我打电话给Push:禁用WebSocket并强迫我打电话使用流媒体

我到底应该什么时候打电话给[super viewWillAppear:],什么时候不打电话?

我应该打电话给Integer.hashCode()吗?

响应请求时,我应该避免打电话给require吗?

从网站拨打电话

雄辩的自我加入-如何打电话

我uitableview(cell = nil)总是不打电话吗?

如何进行超级课程,我可以打电话来处理我的下载内容

我可以打电话给特定的世代GC吗

我应该在接受之前打电话给bind吗?

让 Twilio 等我,然后在有人接电话时给我打电话