Wibracje i dźwięk są ustawiane domyślnie w powiadomieniu

94

Próbuję uzyskać domyślny alarm wibracyjny i dźwiękowy, gdy nadejdzie moje powiadomienie, ale jak dotąd nie mam szczęścia. Wyobrażam sobie, że ma to związek ze sposobem, w jaki ustawiam wartości domyślne, ale nie jestem pewien, jak to naprawić. jakieś pomysły?

public void connectedNotify() {
    Integer mId = 0;
    NotificationCompat.Builder mBuilder =
            new NotificationCompat.Builder(this)
            .setSmallIcon(R.drawable.ic_notify)
            .setContentTitle("Device Connected")
            .setContentText("Click to monitor");

    Intent resultIntent = new Intent(this, MainActivity.class);

    TaskStackBuilder stackBuilder = TaskStackBuilder.create(this);
    stackBuilder.addParentStack(MainActivity.class);
    stackBuilder.addNextIntent(resultIntent);
    PendingIntent resultPendingIntent =     
          PendingIntent.getActivity(getApplicationContext(), 
          0, 
          resultIntent,  
          PendingIntent.FLAG_UPDATE_CURRENT);
    mBuilder.setContentIntent(resultPendingIntent);
    mBuilder.setOngoing(true);
    Notification note = mBuilder.build();
    note.defaults |= Notification.DEFAULT_VIBRATE;
    note.defaults |= Notification.DEFAULT_SOUND;
    NotificationManager mNotificationManager =
        (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
    mNotificationManager.notify(mId, note);

}
Dave Moore
źródło
3
Wszystkie odpowiedzi tylko powtarzają pewną odmianę kodu, który już masz, a żadna z nich nie odpowiada moim zdaniem na pytanie. Twój kod wygląda dobrze, AFAICT. Najprawdopodobniej po prostu brakuje Ci android.permission.VIBRATEpliku AndroidManifest.xml.
Olaf Dietsche
Do kogo może zastosować rozwiązania w tym wątku i nadal nie ma żadnych wibracji w powiadomieniach, może być konieczne najpierw włączenie wibracji kanału powiadomień. Spójrz na to: stackoverflow.com/a/47646166/8551764
Mostafa Arian Nejad

Odpowiedzi:

205

Niektóre fałszywe kody mogą ci pomóc.

   private static NotificationCompat.Builder buildNotificationCommon(Context _context, .....) {
            NotificationCompat.Builder builder = new NotificationCompat.Builder(_context)
            .setWhen(System.currentTimeMillis()).......;
     //Vibration
        builder.setVibrate(new long[] { 1000, 1000, 1000, 1000, 1000 });

     //LED
        builder.setLights(Color.RED, 3000, 3000);

     //Ton
        builder.setSound(Uri.parse("uri://sadfasdfasdf.mp3"));

    return builder;
   }

Dodaj poniżej zezwolenie na wibracje w AndroidManifest.xmlpliku

<uses-permission android:name="android.permission.VIBRATE" />
TeeTracker
źródło
115
vibrateFunkcja +1 wymaga <uses-permission android:name="android.permission.VIBRATE" />pozwolenia
Ashakirov
1
W niektórych przypadkach powinieneś użyć formatu szesnastkowego koloru argb, takiego jak 0xffffffff, zamiast Color.White, ponieważ istnieje niewielka szansa, że ​​urządzenie użytkownika użyje koloru (RGB) jako parametru ARGB, a otrzymasz niewłaściwy kolor. Stało się to ze mną.
Beto Caldas
55
Wibracja ma teraz opóźnienie 1000 ms. Jeśli ustawisz pierwszy na 0, wyłączy się natychmiast. To wzór {opóźnienie, wibracja, sen, wibracja, sen}.
Tom
11
Nie musiałem dodawać <uses-permission android:name="android.permission.VIBRATE" />do pracy.
Iqbal
1
Czy ktoś wie, jak używać setSound na API 26?
Rodrigo Manguinho
61

Rozszerzenie odpowiedzi TeeTrackera,

aby uzyskać domyślny dźwięk powiadomienia, możesz wykonać następujące czynności

NotificationCompat.Builder mBuilder =
            new NotificationCompat.Builder(this)
            .setSmallIcon(R.drawable.ic_notify)
            .setContentTitle("Device Connected")
            .setContentText("Click to monitor");

Uri alarmSound = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);
builder.setSound(alarmSound);

To da ci domyślny dźwięk powiadomienia.

nikoo28
źródło
36

Powiadomienie Wibracje

mBuilder.setVibrate(new long[] { 1000, 1000});

Dźwięk

mBuilder.setSound(Settings.System.DEFAULT_NOTIFICATION_URI);

dla większej opcji dźwięku

Cristiana Chavez
źródło
2
Jeśli chodzi o wibrację, pamiętaj o umieszczeniu <uses-permission android:name="android.permission.VIBRATE" />w pliku AndroidManifest.xml
Aaron Esau
jak długo trwa ta wibracja? czy tylko raz zawibruje?
Zapnologica
13

Dla mnie działa dobrze, możesz spróbować.

 protected void displayNotification() {

        Log.i("Start", "notification");

      // Invoking the default notification service //
        NotificationCompat.Builder  mBuilder =
                new NotificationCompat.Builder(this);
        mBuilder.setAutoCancel(true);

        mBuilder.setContentTitle("New Message");
        mBuilder.setContentText("You have "+unMber_unRead_sms +" new message.");
        mBuilder.setTicker("New message from PayMe..");
        mBuilder.setSmallIcon(R.drawable.icon2);

      // Increase notification number every time a new notification arrives //
        mBuilder.setNumber(unMber_unRead_sms);

      // Creates an explicit intent for an Activity in your app //

        Intent resultIntent = new Intent(this, FreesmsLog.class);

        TaskStackBuilder stackBuilder = TaskStackBuilder.create(this);
        stackBuilder.addParentStack(FreesmsLog.class);

      // Adds the Intent that starts the Activity to the top of the stack //
        stackBuilder.addNextIntent(resultIntent);
        PendingIntent resultPendingIntent =
                stackBuilder.getPendingIntent(
                        0,
                        PendingIntent.FLAG_UPDATE_CURRENT
                );
        mBuilder.setContentIntent(resultPendingIntent);

      //  mBuilder.setOngoing(true);
        Notification note = mBuilder.build();
        note.defaults |= Notification.DEFAULT_VIBRATE;
        note.defaults |= Notification.DEFAULT_SOUND;

        mNotificationManager =
                (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
      // notificationID allows you to update the notification later on. //
        mNotificationManager.notify(notificationID, mBuilder.build());

    }
Selim Raza
źródło
10

Jest to prosty sposób powiadamiania o połączeniu przy użyciu domyślnych wibracji i dźwięku systemu.

private void sendNotification(String message, String tick, String title, boolean sound, boolean vibrate, int iconID) {
    Intent intent = new Intent(this, MainActivity.class);
    intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
    PendingIntent pendingIntent = PendingIntent.getActivity(this, 0 /* Request code */, intent,
            PendingIntent.FLAG_ONE_SHOT);
    Notification notification = new Notification();

    NotificationCompat.Builder notificationBuilder = new NotificationCompat.Builder(this);

    if (sound) {
        notification.defaults |= Notification.DEFAULT_SOUND;
    }

    if (vibrate) {
        notification.defaults |= Notification.DEFAULT_VIBRATE;
    }

    notificationBuilder.setDefaults(notification.defaults);
    notificationBuilder.setSmallIcon(iconID)
            .setContentTitle(title)
            .setContentText(message)
            .setAutoCancel(true)
            .setTicker(tick)
            .setContentIntent(pendingIntent);

    NotificationManager notificationManager =
            (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);

    notificationManager.notify(0 /* ID of notification */, notificationBuilder.build());
}

Dodaj uprawnienia do wibracji, jeśli zamierzasz z nich korzystać:

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

Powodzenia,'.

Maher Abuthraa
źródło
Czy ktoś może mi powiedzieć, dlaczego wibracje nie działają, gdy telefon jest w trakcie rozmowy? LUB czy możemy
Pomogło mi to notificationBuilder.setDefaults (notification.defaults);
Saveen
@ user526206, nie wiem. Nigdy tego nie testowałem. Możesz otworzyć nowe pytanie, ponieważ nie ma ono nic z zachowaniem powiadomień.
Maher Abuthraa
7

Używam następującego kodu i działa dobrze dla mnie.

private void sendNotification(String msg) {
    Log.d(TAG, "Preparing to send notification...: " + msg);
    mNotificationManager = (NotificationManager) this
            .getSystemService(Context.NOTIFICATION_SERVICE);

    PendingIntent contentIntent = PendingIntent.getActivity(this, 0,
            new Intent(this, MainActivity.class), 0);

    NotificationCompat.Builder mBuilder = new NotificationCompat.Builder(
            this).setSmallIcon(R.drawable.ic_launcher)
            .setContentTitle("GCM Notification")
            .setAutoCancel(true)
            .setDefaults(Notification.DEFAULT_ALL)
            .setStyle(new NotificationCompat.BigTextStyle().bigText(msg))
            .setContentText(msg);

    mBuilder.setContentIntent(contentIntent);
    mNotificationManager.notify(NOTIFICATION_ID, mBuilder.build());
    Log.d(TAG, "Notification sent successfully.");
}
Suresh kumar
źródło
2

// ustaw dźwięk powiadomienia

builder.setDefaults(Notification.DEFAULT_VIBRATE);
//OR 
builder.setDefaults(Notification.DEFAULT_SOUND);
Mayuri Khinvasara
źródło
1

Dla Kotlina możesz spróbować tego.

var builder = NotificationCompat.Builder(this,CHANNEL_ID)<br/>
     .setVibrate(longArrayOf(1000, 1000, 1000, 1000, 1000))<br/>
     .setSound(Settings.System.DEFAULT_NOTIFICATION_URI)
Sachin Shakya
źródło
1

Aby obsługiwać wersję SDK> = 26, powinieneś również zbudować NotificationChanel i ustawić tam wzór wibracji i dźwięk. Istnieje przykładowy kod Kotlin:

    val vibrationPattern = longArrayOf(500)
    val soundUri = "<your sound uri>"

    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
            val notificationManager =    
                 getSystemService(Context.NOTIFICATION_SERVICE) as NotificationManager
            val attr = AudioAttributes.Builder()
                        .setUsage(AudioAttributes.USAGE_ALARM)
                        .setContentType(AudioAttributes.CONTENT_TYPE_SONIFICATION)
                        .build()
            val channelName: CharSequence = Constants.NOTIFICATION_CHANNEL_NAME
            val importance = NotificationManager.IMPORTANCE_HIGH
            val notificationChannel =
                NotificationChannel(Constants.NOTIFICATION_CHANNEL_ID, channelName, importance)
                notificationChannel.enableLights(true)
                notificationChannel.lightColor = Color.RED
                notificationChannel.enableVibration(true)
                notificationChannel.setSound(soundUri, attr)
                notificationChannel.vibrationPattern = vibrationPattern
                notificationManager.createNotificationChannel(notificationChannel)
    }

A to jest budowniczy:

 with(NotificationCompat.Builder(applicationContext, Constants.NOTIFICATION_CHANNEL_ID)) {
        setContentTitle("Some title")
        setContentText("Some content")
        setSmallIcon(R.drawable.ic_logo)
        setAutoCancel(true)    
        setVibrate(vibrationPattern)
        setSound(soundUri)
        setDefaults(Notification.DEFAULT_VIBRATE)
        setContentIntent(
            // this is an extension function of context you should build
            // your own pending intent and place it here
            createNotificationPendingIntent(
                Intent(applicationContext, target).apply {
                    flags = Intent.FLAG_ACTIVITY_NEW_TASK or Intent.FLAG_ACTIVITY_CLEAR_TASK
                }
            )
        )

        return build()
    }

Upewnij się, że AudioAttributesjesteś wybrany, aby przeczytać więcej tutaj .

MeLine
źródło