我有一个通知构建器。我想添加通知计时器,如whatsapp呼叫通知。因此,如果我调用updateNotifTime函数,则无效。
NotificationCompat.Builder builder = new NotificationCompat.Builder(context, callChannelId)
.setSmallIcon(R.drawable.call_icon)
.setContentIntent(pendingIntent)
.setOngoing(true)
.setShowWhen(true)
.setWhen(System.currentTimeMillis())
.setPriority(NotificationCompat.PRIORITY_HIGH);
public void updateNotifTime() {
this.callingElapsedRunnable = new Runnable() {
@Override
public void run() {
elapsedTime += 1000;
String timer = DateUtils.calculateTime(elapsedTime);
builder.setWhen(elapsedTime);
callingElapsedHandler.postDelayed(this, 1000);
}
};
callingElapsedHandler.postDelayed(callingElapsedRunnable, 1000);
}
答案 0 :(得分:3)
我为< 5.0 sdk版本添加了自定义布局:
<强>&LT; 5.0 强>
public void startChronometer(String elapsedTime) {
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP && builder != null) {
RemoteViews mContentView = new RemoteViews(context.getPackageName(), R.layout.call_notification);
//timerTxt
TextView timerTxt = new TextView(context);
timerTxt.setId(R.id.timerTxt);
//callTypeTxt
TextView callTypeTxt = new TextView(context);
callTypeTxt.setId(R.id.callType);
//calleeNameTxt
TextView calleeNameTxt = new TextView(context);
calleeNameTxt.setId(R.id.calleeName);
mContentView.setTextViewText(timerTxt.getId(), elapsedTime);
mContentView.setTextViewText(callTypeTxt.getId(), context.getString(R.string.call_in_progress));
builder.setCustomBigContentView(mContentView);
notificationManager.notify(CALL_NOTIFICATION_ID, builder.build());
}
}
其他版本
builder.setUsesChronometer(true);
@Kishore Jethava问题:
Intent intent = new Intent(mContext, YourActivity.class);
intent.putExtra("tappedTime", System.currentTimeMillis());
PendingIntent pendingIntent = PendingIntent.getActivity(mContext, (int) System.currentTimeMillis(), intent, PendingIntent.FLAG_UPDATE_CURRENT);
答案 1 :(得分:1)
private void sendNotification(String from, String messageText) {
Intent intent = new Intent(this, MainActivity.class);
intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, intent, PendingIntent.FLAG_ONE_SHOT);
Uri defaultSoundUri= RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);
NotificationCompat.Builder notificationBuilder = new NotificationCompat.Builder(this)
.setSmallIcon(R.mipmap.ic_launcher)
.setContentTitle(from)
.setContentText(messageText)
.setAutoCancel(true)
.setSound(defaultSoundUri)
.setContentIntent(pendingIntent);
NotificationManager notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
notificationManager.notify(0, notificationBuilder.build());
}
答案 2 :(得分:0)
我用一种非常简单的方法解决了这个问题。 我的初始通知
notification = new NotificationCompat.Builder(this, CALL_CHANNEL_ID)
.setContentText("Incoming Voice Call")
.setContentTitle(getDoctor().name)
.setSmallIcon(R.drawable.ic_baseline_call_received_24)
.setPriority(NotificationCompat.PRIORITY_HIGH)
.setCategory(NotificationCompat.CATEGORY_CALL)
.setShowWhen(true)
.setUsesChronometer(true)
.setFullScreenIntent(voicePendingIntent, true);
startForeground(1, notification.build());
存储服务启动时的时间戳
public void startTimer() {
if (!isTimerRunning) {
startTime = System.currentTimeMillis();
isTimerRunning = true;
} else {
Log.e(TAG, "startTimer request for an already running timer");
}
}
每次调用elapsedTime()(通常在活动中获取时间)时,通知都会更新。
public long elapsedTime() {
if (isTimerRunning()) {
durationMillis = System.currentTimeMillis() - startTime;
notification.setWhen(startTime);
notification.setOnlyAlertOnce(true);
notificationManager.notify(1, notification.build());
return (durationMillis);
} else {
return 0;
}
}