总体思路为 :
1.截取铃声
2.保存入sd卡
3.获取铃声信息
4.将信息和文件路径写入数据库获得铃声Uri
5.将获得的Uri设置为铃声。
核心实现:在
public class DefaultRingtonePreference extends RingtonePreference {
private static final String TAG = "DefaultRingtonePreference";
public DefaultRingtonePreference(Context context, AttributeSet attrs) {
super(context, attrs);
}
@Override
protected void onPrepareRingtonePickerIntent(Intent ringtonePickerIntent) {
super.onPrepareRingtonePickerIntent(ringtonePickerIntent);
/*
* Since this preference is for choosing the default ringtone, it
* doesn't make sense to show a 'Default' item.
*/
ringtonePickerIntent.putExtra(RingtoneManager.EXTRA_RINGTONE_SHOW_DEFAULT, false);
}
@Override
protected void onSaveRingtone(Uri ringtoneUri) { //注意这个方法 他是实现铃声设置的核心方法
RingtoneManager.setActualDefaultRingtoneUri(getContext(), getRingtoneType(), ringtoneUri);
}
@Override
protected Uri onRestoreRingtone() {
return RingtoneManager.getActualDefaultRingtoneUri(getContext(), getRingtoneType());
}
}
DefaultRingtonePreference 单机后出现的是一个AlertDialog 但是在DefaultRingtonePreference没看见任何构造Dialog的信息 显然构建在父亲那的于是出现RingtonePreference的代码:
public class RingtonePreference extends Preference implements PreferenceManager.OnActivityResultListener {
private static final String TAG = "RingtonePreference";
private int mRingtoneType;
private boolean mShowDefault;
private boolean mShowSilent;
private int mRequestCode;
public RingtonePreference(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
TypedArray a = context.obtainStyledAttributes(attrs, com.android.internal.R.styleable.RingtonePreference, defStyle, 0);
mRingtoneType = a.getInt(com.android.internal.R.styleable.RingtonePreference_ringtoneType, RingtoneManager.TYPE_RINGTONE);
mShowDefault = a.getBoolean(com.android.internal.R.styleable.RingtonePreference_showDefault, true);
mShowSilent = a.getBoolean(com.android.internal.R.styleable.RingtonePreference_showSilent, true);
a.recycle();
}
public RingtonePreference(Context context, AttributeSet attrs) {
this(context, attrs, com.android.internal.R.attr.ringtonePreferenceStyle);
}
public RingtonePreference(Context context) {
this(context, null);
}
/**
* Returns the sound type(s) that are shown in the picker.

* @return The sound type(s) that are shown in the picker.
* @see #setRingtoneType(int)
*/
public int getRingtoneType() {
return mRingtoneType;
}
/**
* Sets the sound type(s) that are shown in the picker.

* @param type
*            The sound type(s) that are shown in the picker.
* @see RingtoneManager#EXTRA_RINGTONE_TYPE
*/
public void setRingtoneType(int type) {
mRingtoneType = type;
}
/**
* Returns whether to a show an item for the default sound/ringtone.

* @return Whether to show an item for the default sound/ringtone.
*/
public boolean getShowDefault() {
return mShowDefault;
}
/**
* Sets whether to show an item for the default sound/ringtone. The default
* to use will be deduced from the sound type(s) being shown.

* @param showDefault
*            Whether to show the default or not.
* @see RingtoneManager#EXTRA_RINGTONE_SHOW_DEFAULT
*/
public void setShowDefault(boolean showDefault) {
mShowDefault = showDefault;
}
/**
* Returns whether to a show an item for 'Silent'.

* @return Whether to show an item for 'Silent'.
*/
public boolean getShowSilent() {
return mShowSilent;
}
/**
* Sets whether to show an item for 'Silent'.

* @param showSilent
*            Whether to show 'Silent'.
* @see RingtoneManager#EXTRA_RINGTONE_SHOW_SILENT
*/
public void setShowSilent(boolean showSilent) {
mShowSilent = showSilent;
}
@Override
protected void onClick() { //注意这对DefaultRingtonePreference单机事件左的处理有跳转
// Launch the ringtone picker
Intent intent = new Intent(RingtoneManager.ACTION_RINGTONE_PICKER);
onPrepareRingtonePickerIntent(intent);
getPreferenceManager().getActivity().startActivityForResult(intent, mRequestCode);
}
/**
* Prepares the intent to launch the ringtone picker. This can be modified
* to adjust the parameters of the ringtone picker.

* @param ringtonePickerIntent
*            The ringtone picker intent that can be modified by putting
*            extras.
*/
protected void onPrepareRingtonePickerIntent(Intent ringtonePickerIntent) {
ringtonePickerIntent.putExtra(RingtoneManager.EXTRA_RINGTONE_EXISTING_URI, onRestoreRingtone());
ringtonePickerIntent.putExtra(RingtoneManager.EXTRA_RINGTONE_SHOW_DEFAULT, mShowDefault);
if (mShowDefault) {
ringtonePickerIntent.putExtra(RingtoneManager.EXTRA_RINGTONE_DEFAULT_URI, RingtoneManager.getDefaultUri(getRingtoneType()));
}
ringtonePickerIntent.putExtra(RingtoneManager.EXTRA_RINGTONE_SHOW_SILENT, mShowSilent);
ringtonePickerIntent.putExtra(RingtoneManager.EXTRA_RINGTONE_TYPE, mRingtoneType);
}
/**
* Called when a ringtone is chosen.
* <p>
* By default, this saves the ringtone URI to the persistent storage as a
* string.

* @param ringtoneUri
*            The chosen ringtone's {@link Uri}. Can be null.
*/
protected void onSaveRingtone(Uri ringtoneUri) {
persistString(ringtoneUri != null ? ringtoneUri.toString() : "");
}
/**
* Called when the chooser is about to be shown and the current ringtone
* should be marked. Can return null to not mark any ringtone.
* <p>
* By default, this restores the previous ringtone URI from the persistent
* storage.

* @return The ringtone to be marked as the current ringtone.
*/
protected Uri onRestoreRingtone() {
final String uriString = getPersistedString(null);
return !TextUtils.isEmpty(uriString) ? Uri.parse(uriString) : null;
}
@Override
protected Object onGetDefaultValue(TypedArray a, int index) {
return a.getString(index);
}
@Override
protected void onSetInitialValue(boolean restorePersistedValue, Object defaultValueObj) {
String defaultValue = (String) defaultValueObj;
/*
* This method is normally to make sure the internal state and UI
* matches either the persisted value or the default value. Since we
* don't show the current value in the UI (until the dialog is opened)
* and we don't keep local state, if we are restoring the persisted
* value we don't need to do anything.
*/
if (restorePersistedValue) {
return;
}
// If we are setting to the default value, we should persist it.
if (!TextUtils.isEmpty(defaultValue)) {
onSaveRingtone(Uri.parse(defaultValue));
}
}
@Override
protected void onAttachedToHierarchy(PreferenceManager preferenceManager) {
super.onAttachedToHierarchy(preferenceManager);
preferenceManager.registerOnActivityResultListener(this);
mRequestCode = preferenceManager.getNextRequestCode();
}
public boolean onActivityResult(int requestCode, int resultCode, Intent data) {  //注意该方法回调了子类的onSaveRingtone方法
if (requestCode == mRequestCode) {
if (data != null) {
Uri uri = data.getParcelableExtra(RingtoneManager.EXTRA_RINGTONE_PICKED_URI);
if (callChangeListener(uri != null ? uri.toString() : "")) {
onSaveRingtone(uri);
}
}
return true;
}
return false;
}
}
对DefaultRingtonePreference的单机跳转到 RingtonePickerActivity.java 下篇
android 铃声设置流程讲解 二继续讲解

android 铃声设置流程讲解相关推荐

  1. android 铃声设置失败,Android铃声设置错误

    点击按钮运行set_ringtone.没有错误,它设置铃声.但是当我第二次点击按钮时,出现错误.Android铃声设置错误 public void set_ringtone(Context conte ...

  2. android 铃声设置失败,无法通过Android代码设置铃声

    我正在开发一个应用程序,它将随机设置用户已选择的铃声列表中的铃声.无法通过Android代码设置铃声 虽然我的代码适用于Android N及以上版本,但我遇到了Android M及以下版本的问题.我为 ...

  3. android 6.0 重启 丢失 壁纸,android6.0 壁纸设置流程讲解

    主要以在launcher界面长按点击wallpaper按钮来设置壁纸的流程. 当我们点击wallpaper按钮后进入WallpaperPickerActivity.java界面,分三块上为设置按钮,中 ...

  4. android 铃声设置失败,Android设置铃声失败

    我尝试下面的代码,它不设置铃声. "ff"的logcat条目表示为空,所以我猜这个URI没有正确连接?,我似乎无法弄清楚我的代码中哪里出错了.Android设置铃声失败 Strin ...

  5. Android8.0开机铃声设置流程

    这里还是以实际项目出发,将遇到的问题总结一下. 1.板子上没有音量键,可以使用命令行模拟音量键: adb shell input keyevent 24:音量加 adb shell input key ...

  6. Android音量设置流程干货版

    原址 1.     音量级数定义 在AudioService.Java中定义了最大音量MAX_STREAM_VOLUME,手机的设置property可以覆盖它. 2.     音量初始化 initSt ...

  7. android 铃声设置文件夹

    1 系统自带声音文件存放的位置和内容. 1.1 总目录:/system/media/audio  1.2 闹钟:/system/media/audio/alarms  1.3 短信通知:/system ...

  8. Android 铃声设置

    铃声预制:     添加音频文件 frameworks/base/data/sounds     修改mk文件   frameworks/base/data/sounds/AllAudio.mk   ...

  9. android 5.0 设置铃声,android5.0联系人铃声设置和来电读取分析

    android5.0联系人铃声设置和来电读取 一,单个联系人的铃声设置流程 1,联系人编辑界面下菜单设置来电铃声,会弹出一个ringtone列表供用户选择. 从ContactEditorFragmen ...

最新文章

  1. 函数计算 【题目描述】
  2. oom 如何避免 高并发_如何设计这样一个高并发系统?
  3. [IE兼容性] Table 之边框
  4. 机器智能芯片 10 大新秀!华为抢占一席,Google 占比最多!
  5. CCNP路由重分发(四)EIGRP-to-ISIS
  6. checkbox选中并记住状态(分页)
  7. html5输入框点击后消除高光,请问(VR渲染)光域网的灯光怎么把“高光”去掉?...
  8. 完美电脑主机一拖二,让你夫妻不再抢电脑,一台主机两人独立玩
  9. python爬虫入门之爬取英雄联盟官网的所有英雄数据
  10. 使用Fiddler抓取websocket包-Android
  11. STM32MP157移植Qt5.12.10
  12. 电信物联卡稳定的apn接入点_0月租的电信纯流量卡怎么样?
  13. 不等于在python中怎么打_在python中不等于用什么来表示
  14. 【阿里云】第一次进行域名注册、备案以及使用全过程
  15. JSON数据遍历之for-in
  16. HP-SuperDome MP收集日志
  17. 电脑版微信发不出去文字和文件
  18. 外汇交易时间窗口,交易者须知
  19. 罗永浩新公司准备招人,AI写一篇代码文档只需2步,如何优雅地乱搞Python代码、一大波数学资料来袭!AI前沿论文 | ShowMeAI资讯日报
  20. gcov介绍+使用实例

热门文章

  1. Python的安装及应用
  2. 手机摄像头不可思议的3个功能,普通人一定不知道!
  3. 受得了多大的委屈,才做得了多大的事
  4. 特征值和特征向量在现代控制理论的简单应用
  5. 中国科技馆推出“科技冬奥,逐梦冰雪”主题月活动
  6. 2021年压力管道巡检维护试题及解析及压力管道巡检维护模拟考试题库
  7. 如何将doc格式转换成pdf格式的文件
  8. CSS中的text-align不起作用
  9. 盘点23个提高开发效率和美观性的 VSCode 插件
  10. window.speechSynthesis.speak 不能自动执行问题