热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

Android仿微信新消息提示音

本篇文章主要介绍了Android仿微信新消息提示音的相关知识。具有很好的参考价值。下面跟着小编一起来看下吧

怕有些人不知道怎么进入微信的新消息提示音功能,我这里说下操作步骤:

打开微信----我---设置---新消息提醒---新消息提示音。

经过以上的步骤就进入了这样的界面

具体实现的步骤。

难点之一:获取到手机系统的提示音,并将它们显示在一个listview里面。

参考如下代码:

// 获得RingtoneManager对象 
RingtoneManager manager = new RingtoneManager(this); 
// 设置RingtoneManager对象的类型为TYPE_NOTIFICATION,这样只会获取到notification的对应内容 
manager.setType(RingtoneManager.TYPE_NOTIFICATION); 
Cursor cursor = manager.getCursor(); 
int num = cursor.getCount(); 
Log.i("tag", num + "消息音个数"); 
// 存储消息音名字的arrayList 
ArrayList ringtOneList= new ArrayList(); 
for (int i = 0; i 

将获取到的消息提示音的名字,加入到arrayList里。

先将主界面的信息贴上来,看一下,我再慢慢解释:

package jz.his.activity; 

import java.util.ArrayList; 

import jz.his.adapter.RingtoneAdapter; 
import jz.his.jzhis.R; 
import jz.his.util.SharedPreferenceUtil; 
import android.app.Activity; 
import android.content.Intent; 
import android.database.Cursor; 
import android.media.Ringtone; 
import android.media.RingtoneManager; 
import android.net.Uri; 
import android.os.Bundle; 
import android.util.Log; 
import android.view.View; 
import android.view.Window; 
import android.widget.AdapterView; 
import android.widget.AdapterView.OnItemClickListener; 
import android.widget.ListView; 

public class RingtoneActivity extends Activity { 
 ArrayList ringtoneList; 
 ListView listView; 
 RingtoneManager manager; 
 RingtoneAdapter adapter; 
 String ringName = ""; 

 /** 
  * 选择铃声的uri 
  */ 
 Uri uri = null; 

 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
  super.onCreate(savedInstanceState); 
  requestWindowFeature(Window.FEATURE_NO_TITLE); 
  setContentView(R.layout.activity_ringtone); 
  listView = (ListView) findViewById(R.id.ringtone); 
  getRingtone(); 
  // initRingtoneManager(); 

  // ringtOneList= FunctionActivity.ringtoneList; 
  adapter = new RingtoneAdapter(this, ringtoneList, getIndex()); 
  listView.setAdapter(adapter); 
  // 设置从第getIndex()行开始显示 
  listView.setSelection(getIndex()); 
  listView.setOnItemClickListener(new OnItemClickListener() { 

   @SuppressWarnings("static-access") 
   @Override 
   public void onItemClick(AdapterView<&#63;> parent, View view, 
     int position, long id) { 
    // 当点击的item是第一个“跟随系统”时 
    if (position == 0) { 
     // 得到系统默认的消息uri 
     Uri defalutUri = manager 
       .getDefaultUri(RingtoneManager.TYPE_NOTIFICATION); 
     // 通过URI获得系统默认的Ringtone发出声音 
     Ringtone defalutRingtOne= manager.getRingtone( 
       RingtoneActivity.this, defalutUri); 
     defalutRingtone.play(); 
     ringName = "跟随系统"; 
     uri = null; 
    } else { 
     // 当点击的item不是第一个“跟随系统”时,获得的铃声要减一才对 
     Ringtone ringtOne= manager.getRingtone(position - 1); 
     uri = manager.getRingtoneUri(position - 1); 
     ringtone.play(); 
     ringName = ringtone.getTitle(RingtoneActivity.this); 

    } 
    adapter.first = new int[ringtoneList.size()]; 
    if (adapter.first[position] == 0) { 
     adapter.first[position] = 1; 
    } else { 
     adapter.first[position] = 0; 
    } 
    adapter.notifyDataSetChanged(); 

   } 
  }); 
 } 

 /** 
  * 初始化RingtoneManager对象,在listview的点击事件里面,用到了 
  */ 
 private void initRingtoneManager() { 
  manager = new RingtoneManager(this); 
  manager.setType(RingtoneManager.TYPE_NOTIFICATION); 
  manager.getCursor(); 
 } 

 /** 
  * 得到当前铃声的行数 
  */ 
 private int getIndex() { 
  for (int i = 0; i (); 
  for (int i = -1; i 

解释1:

因为listView显示的第一行是一个“追随系统”的item,所以我在适配数据的时候,有些小改变,在i=-1的时候,将ringtoneList添加为“追随系统”,其他的不变。因为进行了这样的处理,那么在点击各个item时候,获得铃声并进行播放时候,要做这样的处理:

Ringtone ringtOne= manager.getRingtone(position - 1); 

解释2:

最终将选择的铃声uri路径以String的格式存入到sharedPreference中。

Bitmap btm = BitmapFactory.decodeResource(getResources(), 
  R.drawable.ic_launcher); 
// 这里大图标,小图标刚好相反 
NotificationCompat.Builder builder = new NotificationCompat.Builder( 
  this).setSmallIcon(R.drawable.ic_launcher) 
  .setContentTitle(title).setContentText(content) 
  .setTicker(tickerText); 

if (SharedPreferenceUtil 
  .getBoolean(this, SharedPreferenceUtil.IS_SOUND)) { 

} else { 
 // 如果消息声音开启 
 if (!SharedPreferenceUtil.getStringNull(OnlineService.this, 
   SharedPreferenceUtil.url_string).equals("")) { 
  // 如果选择了其他的系统声音 
  builder.setSound(Uri.parse(SharedPreferenceUtil.getString( 
    OnlineService.this, SharedPreferenceUtil.url_string))); 
 } else { 
  // 默认的系统声音 
  builder.setDefaults(Notification.DEFAULT_SOUND); 
 } 
} 

if (SharedPreferenceUtil.getBoolean(this, 
  SharedPreferenceUtil.IS_VIBRATE)) { 

} else { 
 builder.setDefaults(Notification.DEFAULT_VIBRATE); 
} 
// 构建一个Intent 
Intent intent = new Intent(this, FunctionActivity.class); 

intent.putExtra("messageData","messageData" ); 
sendData(); 
// 封装一个Intent 
PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, 
  intent, PendingIntent.FLAG_ONE_SHOT); 
// 设置通知主题的意图 
builder.setContentIntent(pendingIntent); 
// 获取通知管理器对象 
NotificationManager notificatiOnManager= (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); 
notificationManager.notify(id, builder.build()); 

注意:如果是要选择其他的声音,直接是n.sound = 其他声音的Uri

这个真的非常重要,就直接这样就可以了,看网上一大堆什么

notification.sound = Uri.withAppendedPath(Audio.Media.INTERNAL_CONTENT_URI, "6"); //使用系统提供的铃音

解释3:

当点击保存按钮后,就进入到之前的界面,因为我之前的界面是一个viewpager+fragment的一个界面,一个activity里面加入了四个Fragment的这样的一个界面。进入到主activity时候,进行判断:

/** 
 * 选择消息提示音后,跳转到功能界面后,直接将其跳转设置界面 
*/ 
private void selectRingtone() { 
  String ringName = getIntent().getStringExtra("ringName"); 
  Log.e("tag", ringName+"传过来的值"); 
  if (ringName != null) { 
   pager.setCurrentItem(2); 
  } 
 } 

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


推荐阅读
  • 国内BI工具迎战国际巨头Tableau,稳步崛起
    尽管商业智能(BI)工具在中国的普及程度尚不及国际市场,但近年来,随着本土企业的持续创新和市场推广,国内主流BI工具正逐渐崭露头角。面对国际品牌如Tableau的强大竞争,国内BI工具通过不断优化产品和技术,赢得了越来越多用户的认可。 ... [详细]
  • Android 渐变圆环加载控件实现
    本文介绍了如何在 Android 中创建一个自定义的渐变圆环加载控件,该控件已在多个知名应用中使用。我们将详细探讨其工作原理和实现方法。 ... [详细]
  • 本文详细介绍如何使用arm-eabi-gdb调试Android平台上的C/C++程序。通过具体步骤和实用技巧,帮助开发者更高效地进行调试工作。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • CSS 布局:液态三栏混合宽度布局
    本文介绍了如何使用 CSS 实现液态的三栏布局,其中各栏具有不同的宽度设置。通过调整容器和内容区域的属性,可以实现灵活且响应式的网页设计。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 本文介绍了如何使用jQuery根据元素的类型(如复选框)和标签名(如段落)来获取DOM对象。这有助于更高效地操作网页中的特定元素。 ... [详细]
  • 本文将详细介绍如何使用剪映应用中的镜像功能,帮助用户轻松实现视频的镜像效果。通过简单的步骤,您可以快速掌握这一实用技巧。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文介绍如何在 Xcode 中使用快捷键和菜单命令对多行代码进行缩进,包括右缩进和左缩进的具体操作方法。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • 如何在WPS Office for Mac中调整Word文档的文字排列方向
    本文将详细介绍如何使用最新版WPS Office for Mac调整Word文档中的文字排列方向。通过这些步骤,用户可以轻松更改文本的水平或垂直排列方式,以满足不同的排版需求。 ... [详细]
author-avatar
迷-糊-娃娃
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有