android微信加人有提示音吗,Android仿微信新消息提示音

環信聊天消息提示音的實現 仿微信新消息提示音設置。

思路:用RingtoneManager查詢出title,Ringtone,uri信息,title用來展示,Ringtone用來播放,uri設置提示音時保存到本地,消息到來時,從本地獲取存儲的Uri,然后根據uri獲取Ringtone對象,播放提示音。

效果圖:

d9343cd297481b7e63c745b8eabe1e6e.png

布局文件用ListView

實體類,用來存儲提示音信息:

/** *@author 強 *@time 2017-03-01 10:49 * @類描述:用於存儲ringtone對象和uri * @變更記錄: */

public class RingtoneBean {

private String title;//提示音標題

private String uriPath;//提示音Uri路徑

private Ringtone ringtone;

public RingtoneBean(String title, String uriPath, Ringtone ringtone) {

this.title = title;

this.uriPath = uriPath;

this.ringtone = ringtone;

}

public String getTitle() {

return title;

}

public void setTitle(String title) {

this.title = title;

}

public String getUriPath() {

return uriPath;

}

public void setUriPath(String uriPath) {

this.uriPath = uriPath;

}

public Ringtone getRingtone() {

return ringtone;

}

public void setRingtone(Ringtone ringtone) {

this.ringtone = ringtone;

}

}

工具類核心方法,獲取提示音列表

public List getRingtoneBeanList(int type) { List resArr = new ArrayList<>(); RingtoneManager manager = new RingtoneManager(mContext); manager.setType(type); Cursor cursor = manager.getCursor(); RingtoneBean bean = null; if (cursor.moveToFirst()) { do { //獲取uri廢了一番功夫,api用的23,好多方法沒有了,這句還是查看RingtoneManager源碼找到的。以后還是要多看系統源碼。 Uri uri = ContentUris.withAppendedId(Uri.parse(cursor.getString(RingtoneManager.URI_COLUMN_INDEX)), cursor .getLong(RingtoneManager.ID_COLUMN_INDEX)); Log.e("uri",uri.toString()); String title = cursor.getString(RingtoneManager.TITLE_COLUMN_INDEX); Ringtone ringtone = getRingtoneByUriPath(type, uri.toString()); bean = new RingtoneBean(title,uri.toString(),ringtone); resArr.add(bean); } while (cursor.moveToNext());

}

return resArr;

}

有了數據,接下來就是適配adapter了

/** *@author 丁建強 *@time 2017-03-01 13:00 * @類描述:提示音適配器 * @變更記錄: */

public class SoundAdapter extends BaseAdapter {

private Context mContext;

private int index;//當前選中的index

private List list;

public SoundAdapter(Context mContext, List list) {

this.mContext = mContext;

this.list = list;

}

public void setCurrentIndex(int index) {

this.index = index;

notifyDataSetChanged();

}

@Override

public int getCount() {

return list == null ? 0 : list.size();

}

@Override

public Object getItem(int i) {

return list.get(i);

}

@Override

public long getItemId(int i) {

return i;

}

@Override

public View getView(int i, View view, ViewGroup viewGroup) {

ViewHolder holder = null;

if (view == null) {

view = View.inflate(mContext, R.layout.activity_sound_item, null);

holder = new ViewHolder(view);

view.setTag(holder);

} else {

holder = (ViewHolder) view.getTag();

}

holder.tvName.setText(list.get(i).getTitle());

if (index == i) {

holder.iv_sound.setImageResource(R.mipmap.checked);

} else {

holder.iv_sound.setImageResource(R.mipmap.unckecked);

}

return view;

}

static class ViewHolder {

public TextView tvName;

public ImageView iv_sound;

public ViewHolder(View view) {

tvName = (TextView) view.findViewById(R.id.tv_sound_name);

iv_sound = (ImageView) view.findViewById(R.id.iv_sound);

}

}

}

listview點擊時,選中當前項,並播放選中的提示音

listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {

@Override

public void onItemClick(AdapterView> adapterView, View view, int i, long l) {

adapter.setCurrentIndex(i);//選中當前項

//停止播放之前的

if (tempRingtone != null && tempRingtone.isPlaying()) {

tempRingtone.stop();

}

tempRingtone = ringtoneBeanList.get(i).getRingtone();

tempRingtone.play();

saveIndex = i;

}

});

點保存按鈕時,把選擇的提示音的uri保存到本地

tvSave.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View view) {

String uriPath = ringtoneBeanList.get(saveIndex).getUriPath();

String title = ringtoneBeanList.get(saveIndex).getTitle();

SharedPreferences.Editor editor = preferences.edit();

if (type == 0) {

editor.putString("private_soundTitle", title);

editor.putString("private_soundUriPath", uriPath);

} else {

editor.putString("group_soundTitle", title);

editor.putString("group_soundUriPath", uriPath);

}

editor.commit();

finish();

}

});

這個功能就差不多了,等環信聊天消息到來時調用環信的EaseNotifier,修改此方法,環信默認的提示音是系統的提示音,可以更改去播放自己設置保存到本地的提示音,自定義提示音就實現了。

/** * 手機震動和聲音提示 */

public void viberateAndPlayTone(EMMessage message) {

if (message != null) {

if (EMClient.getInstance().chatManager().isSlientMessage(message)) {

return;

}

}

if (System.currentTimeMillis() - lastNotifiyTime < 1000) {

// received new messages within 2 seconds, skip play ringtone

return;

}

try {

lastNotifiyTime = System.currentTimeMillis();

// 判斷是否處於靜音模式

if (audioManager.getRingerMode() == AudioManager.RINGER_MODE_SILENT) {

EMLog.e(TAG, "in slient mode now");

return;

}

EaseSettingsProvider settingsProvider = EaseUI.getInstance().getSettingsProvider();

if (settingsProvider.isMsgVibrateAllowed(message)) {

long[] pattern = new long[]{0, 180, 80, 120};

vibrator.vibrate(pattern, -1);

}

if (settingsProvider.isMsgSoundAllowed(message)) {

if (ringtone == null) {

Uri notificationUri = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);

ringtone = RingtoneManager.getRingtone(appContext, notificationUri);

if (ringtone == null) {

EMLog.d(TAG, "cant find ringtone at:" + notificationUri.getPath());

return;

}

}

if (!ringtone.isPlaying()) {

String vendor = Build.MANUFACTURER;

ringtone.play();

// for samsung S3, we meet a bug that the phone will

// continue ringtone without stop

// so add below special handler to stop it after 3s if

// needed

if (vendor != null && vendor.toLowerCase().contains("samsung")) {

Thread ctlThread = new Thread() {

public void run() {

try {

Thread.sleep(3000);

if (ringtone.isPlaying()) {

ringtone.stop();

}

} catch (Exception e) {

}

}

};

ctlThread.run();

}

}

}

} catch (Exception e) {

e.printStackTrace();

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值