在按下通知时创建操作,Android

Creating an action on notification being pressed, Android

提问人:PKYNI 提问时间:2/11/2013 最后编辑:PKYNI 更新时间:2/22/2013 访问量:1592

问:

所以似乎无法对其进行配置或正常运行。

尝试获取打开 MainActivity3 文件的通知,然后让它随心所欲地运行,目前只是为了让它播放声音。

对 android 开发完全陌生,但我认为我走对了路。 你会看到我有两种方法,但不能让任何一种方法起作用。

MainActivity.java

package com.example.firstapp;

import android.media.MediaPlayer;
//import android.media.RingtoneManager;
import android.os.Bundle;
import android.os.Vibrator;
import android.app.Activity;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.support.v4.app.NotificationCompat;
import android.view.Menu;
//import android.app.*;
import android.view.*;
import android.widget.*;

public class MainActivity extends Activity {

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    //vibrate controls

    //Notification
    NotificationCompat.Builder mBuilder = new NotificationCompat.Builder(this)
        .setSmallIcon(R.drawable.follownavi)
            .setContentTitle("Hey")
            .setContentText("");   

    PendingIntent pendingIntent;
    //Intent intent = new Intent();

   Intent intent= new Intent(MainActivity3.onNewIntent(), MainActivity3.class);
   intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_SINGLE_TOP);

   //intent.setClass(getApplicationContext(),MainActivity3.class);
   pendingIntent =  PendingIntent.getActivity(getApplicationContext(), 0, intent, 0);
   mBuilder.addAction(R.drawable.follownavi,"LISTEN",pendingIntent);
   mBuilder.setContentIntent(pendingIntent);

   NotificationManager notificationManager = (NotificationManager)     getSystemService(Context.NOTIFICATION_SERVICE);
   notificationManager.notify(1, mBuilder.build());



@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.activity_main, menu);
    return true;
}

@Override
public boolean onTouchEvent(MotionEvent event) {
    //get touch location
    int x = (int)event.getX();
    int y = (int)event.getY();
    //put on screen
    TextView tester = (TextView) findViewById(R.id.textView1);
    tester.setText("this is x:" + x + " and this is y:" + y);

    //move image
    ImageView iv = (ImageView) findViewById(R.id.NaviFollow);

    if(y > 222)
    {
    iv.setX(x - 125);
    iv.setY(y - 350);


    //cause vibration
    Vibrator v = (Vibrator) getSystemService(VIBRATOR_SERVICE);
    v.vibrate(300);
    }

return true;
}



}

一旦通知被调用并出现,它就意味着运行此文件 主活动3

 package com.example.firstapp;


import android.app.Activity;
import android.media.MediaPlayer;
import android.os.Bundle;

public class MainActivity3 extends Activity {

protected Context onNewIntent()
{
MediaPlayer mp2 = MediaPlayer.create(getApplicationContext(), R.raw.listen);
 mp2.start();
return null;


}
}

错误似乎是调用是静态的,但它想要无效,非常混乱 错误代码

无法对类型为 MainActivity3 MainActivity 的非静态方法 onNewIntent() 进行静态引用.java /firstApp/src/com/example/firstapp 第 38 行

如果我将方法更改为适合,那么 mediaplayer getApplicationContext 将不起作用

在做了更多的研究之后,我觉得清单可能会阻止它,但仍然不确定 android 的结构。

清单

 <?xml version="1.0" encoding="utf-8"?>
 <manifest xmlns:android="http://schemas.android.com/apk/res/android"
 package="com.example.firstapp"
 android:versionCode="1"
 android:versionName="1.0" >
 <uses-permission android:name="android.permission.VIBRATE"/>
 <uses-sdk
    android:minSdkVersion="14"
    android:targetSdkVersion="17" />


<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />



<application
    android:allowBackup="true"
    android:icon="@drawable/navibutton"
    android:label="Navi"
    android:theme="@style/AppTheme" >



    <activity
        android:name="com.example.firstapp.MainActivity"
        android:label="@string/app_name" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>

    </activity>
            <receiver android:enabled="true" android:name=".BootUpReceiver"
    android:permission="android.permission.RECEIVE_BOOT_COMPLETED">
                                <intent-filter>
            <action android:name="android.intent.action.BOOT_COMPLETED" />
            <category android:name="android.intent.category.DEFAULT" />
    </intent-filter>    
    </receiver>
    </application>

</manifest>

请帮忙,因为真的陷入困境并想放弃

音频 Android-intent 通知 android-pendingintent

评论

0赞 Yaroslav Mytkalyk 2/13/2013
您是否知道它应该在您单击通知时调用 acitivity3,而不是在它出现时调用?对于通知,最好使用 getApplicationContext,而不是 getBaseContext。
0赞 PKYNI 2/13/2013
是的,我希望它在单击通知时调用它,我尝试更改为 getApplicationContext,但不确定我是否了解区别是什么。基本上,当单击通知时,希望它从 MainActivity3 运行一个函数

答:

0赞 Yaroslav Mytkalyk 2/13/2013 #1

您没有使用 PendingIntent 执行任何操作。您应该在调用 build() 之前在 Notification Builder 中设置它

mBuilder.setContentIntent(pendingIntent);

此外,您必须知道,创建新 Activity 并在 onCreate 上执行某些操作并不是一个好主意。例如,如果需要在同一活动中显示 Toast,您可以在 Intent 中设置特定数据,并在 onNewIntent() 中执行此操作。 接受的答案包含用于配置新意图处理的示例。

Android:new Intent() 使用 android:launchMode=“singleTop” 启动新实例

评论

0赞 PKYNI 2/13/2013
好的并没有真正帮助,我认为它现在正在获取正确的文件和正确的方法/函数,但他们的声明有问题。目前 MainActivity 中的通知构造函数是