Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/188.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何通过我的活动在Android中设置铃声?_Android_Android Activity_Ringtone - Fatal编程技术网

如何通过我的活动在Android中设置铃声?

如何通过我的活动在Android中设置铃声?,android,android-activity,ringtone,Android,Android Activity,Ringtone,我正试图找到一种方法,通过Android活动中的代码设置新的默认铃声 我已经将铃声下载到bytearray中,您可以使用内置的铃声参考类。AndroidGuys对此有一个很好的教程。最后,我设法将默认铃声设置为我下载的铃声。 下载代码不包括在下面,只是需要设置为默认铃声 File k = new File(path, "mysong.mp3"); // path is a file to /sdcard/media/ringtone ContentValues values = new Con

我正试图找到一种方法,通过Android活动中的代码设置新的默认铃声


我已经将铃声下载到
bytearray

中,您可以使用内置的铃声参考类。AndroidGuys对此有一个很好的教程。

最后,我设法将默认铃声设置为我下载的铃声。 下载代码不包括在下面,只是需要设置为默认铃声

File k = new File(path, "mysong.mp3"); // path is a file to /sdcard/media/ringtone

ContentValues values = new ContentValues();
values.put(MediaStore.MediaColumns.DATA, k.getAbsolutePath());
values.put(MediaStore.MediaColumns.TITLE, "My Song title");
values.put(MediaStore.MediaColumns.SIZE, 215454);
values.put(MediaStore.MediaColumns.MIME_TYPE, "audio/mp3");
values.put(MediaStore.Audio.Media.ARTIST, "Madonna");
values.put(MediaStore.Audio.Media.DURATION, 230);
values.put(MediaStore.Audio.Media.IS_RINGTONE, true);
values.put(MediaStore.Audio.Media.IS_NOTIFICATION, false);
values.put(MediaStore.Audio.Media.IS_ALARM, false);
values.put(MediaStore.Audio.Media.IS_MUSIC, false);

//Insert it into the database
Uri uri = MediaStore.Audio.Media.getContentUriForPath(k.getAbsolutePath());
Uri newUri = this.getContentResolver().insert(uri, values);

RingtoneManager.setActualDefaultRingtoneUri(
  myActivity,
  RingtoneManager.TYPE_RINGTONE,
  newUri
);  
无论如何,我不完全理解这段代码在做什么

铃声管理器需要一个要设置为新铃声的文件的uri。但此uri不能直接连接到SD卡,如“/sdcard/media/ringtones/mysong.mp3”。那不行

您需要的是文件的外部文件uri,它可能类似于 “/external/audio/media/46”

46是MediaStore数据库中列的id,因此需要首先将SD卡文件添加到数据库中

无论如何,mediastore如何维护其ID?这个数字可能会非常高,因为您多次执行此操作


我需要自己删除此行吗?问题是,有时我甚至无法控制文件的删除,因为它可以通过文件浏览器直接从SD卡中删除。

我从Android的媒体应用程序中找到了这段代码

Settings.System.putString(resolver, 
Settings.System.RINGTONE, ringUri.toString());

这是我的工作表。

这是我使用的代码!我希望这会有帮助。
public void setRingtone() {
  String ringtoneuri = Environment.getExternalStorageDirectory().getAbsolutePath() + "/media/ringtone";
  File file1 = new File(ringtoneuri);
  file1.mkdirs();
  File newSoundFile = new File(ringtoneuri, "myringtone.mp3");


  Uri mUri = Uri.parse("android.resource://globalapps.funnyringtones/raw/sound_two.mp3");


  ContentResolver mCr = this.getContentResolver();
  AssetFileDescriptor soundFile;
  try {
   soundFile = mCr.openAssetFileDescriptor(mUri, "r");
  } catch (FileNotFoundException e) {
   soundFile = null;
  }

  try {
   byte[] readData = new byte[1024];
   FileInputStream fis = soundFile.createInputStream();
   FileOutputStream fos = new FileOutputStream(newSoundFile);
   int i = fis.read(readData);

   while (i != -1) {
    fos.write(readData, 0, i);
    i = fis.read(readData);
   }

   fos.close();
  } catch (IOException io) {
  }

  ContentValues values = new ContentValues();
  values.put(MediaStore.MediaColumns.DATA, newSoundFile.getAbsolutePath());
  values.put(MediaStore.MediaColumns.TITLE, "my ringtone");
  values.put(MediaStore.MediaColumns.MIME_TYPE, "audio/mp3");
  values.put(MediaStore.MediaColumns.SIZE, newSoundFile.length());
  values.put(MediaStore.Audio.Media.ARTIST, R.string.app_name);
  values.put(MediaStore.Audio.Media.IS_RINGTONE, true);
  values.put(MediaStore.Audio.Media.IS_NOTIFICATION, true);
  values.put(MediaStore.Audio.Media.IS_ALARM, true);
  values.put(MediaStore.Audio.Media.IS_MUSIC, false);

  Uri uri = MediaStore.Audio.Media.getContentUriForPath(newSoundFile.getAbsolutePath());
  Uri newUri = mCr.insert(uri, values);
  try {
   Uri rUri = RingtoneManager.getValidRingtoneUri(this);
   if (rUri != null)
    ringtoneManager.setStopPreviousRingtone(true);
   RingtoneManager.setActualDefaultRingtoneUri(getApplicationContext(), RingtoneManager.TYPE_RINGTONE, newUri);
   Toast.makeText(this, "New Rigntone set", Toast.LENGTH_SHORT).show();
  } catch (Throwable t) {
   Log.e("sanjay in catch", "catch exception"+e.getMessage());
  }

 }
这也是最重要的


快乐编码

我无法对解决方案发表评论,因为我在堆栈溢出方面没有足够的声誉。。。我只想添加一种方法,将音频文件添加到媒体数据库中,而不直接访问数据库,从而避免重复。 该解决方案基于MediaScannerConnection,这是我使用的代码:

    String[] files = { audioFullPath };
    MediaScannerConnection.scanFile(
        getApplicationContext(),
        files,
        null,
        new OnScanCompletedListener() {
            @Override
            public void onScanCompleted(String path, Uri uri) {
                Log.v("myapp", "file " + path + " was scanned seccessfully: " + uri);
            }
        }
    );

Vidar的回答太长,每次您想将歌曲设置为铃声时,它都会添加重复条目。你应该试试这个

Uri newUri=Uri.parse("content://media/external/audio/media/"+ID);  
try {
      RingtoneManager.setActualDefaultRingtoneUri(context, RingtoneManager.TYPE_RINGTONE, newUri);
    }
catch (Throwable t) {


                  }

提供铃声选择的意图

final Uri currentTone= RingtoneManager.getActualDefaultRingtoneUri(MainActivity.this, RingtoneManager.TYPE_ALARM);
                Intent intent = new Intent(RingtoneManager.ACTION_RINGTONE_PICKER);
                intent.putExtra(RingtoneManager.EXTRA_RINGTONE_TYPE, RingtoneManager.TYPE_RINGTONE);
                intent.putExtra(RingtoneManager.EXTRA_RINGTONE_TITLE, "Select Tone");
                intent.putExtra(RingtoneManager.EXTRA_RINGTONE_EXISTING_URI, currentTone);
                intent.putExtra(RingtoneManager.EXTRA_RINGTONE_SHOW_SILENT, false);
                intent.putExtra(RingtoneManager.EXTRA_RINGTONE_SHOW_DEFAULT, true);
                startActivityForResult(intent, 999);
然后在ActivityResult中捕获选择的结果

protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        if(requestCode == 999 && resultCode == RESULT_OK){
            Uri uri = data.getParcelableExtra(RingtoneManager.EXTRA_RINGTONE_PICKED_URI);
            txtView.setText("From :" + uri.getPath());
            //Set selected ringtone here.
            RingtoneManager.setActualDefaultRingtoneUri(
                    this,
                    RingtoneManager.TYPE_RINGTONE,
                    uri
            );
        }
    }

我已经试过这些代码了,它们会有帮助的

  private void setRingtone(Context context, String path) {
    if (path == null) {
        return;
    }
    File file = new File(path);
    ContentValues contentValues = new ContentValues();
    contentValues.put(MediaStore.MediaColumns.DATA, file.getAbsolutePath());
    String filterName = path.substring(path.lastIndexOf("/") + 1);
    contentValues.put(MediaStore.MediaColumns.TITLE, filterName);
    contentValues.put(MediaStore.MediaColumns.MIME_TYPE, "audio/mp3");
    contentValues.put(MediaStore.MediaColumns.SIZE, file.length());
    contentValues.put(MediaStore.Audio.Media.IS_RINGTONE, true);
    Uri uri = MediaStore.Audio.Media.getContentUriForPath(path);
    Cursor cursor = context.getContentResolver().query(uri, null, MediaStore.MediaColumns.DATA + "=?", new String[]{path}, null);
    if (cursor != null && cursor.moveToFirst() && cursor.getCount() > 0) {
        String id = cursor.getString(0);
        contentValues.put(MediaStore.Audio.Media.IS_RINGTONE, true);
        context.getContentResolver().update(uri, contentValues, MediaStore.MediaColumns.DATA + "=?", new String[]{path});
        Uri newuri = ContentUris.withAppendedId(uri, Long.valueOf(id));
        try {
            RingtoneManager.setActualDefaultRingtoneUri(context, RingtoneManager.TYPE_RINGTONE, newuri);
            Toast.makeText(context, "Set as Ringtone Successfully.", Toast.LENGTH_SHORT).show();
        } catch (Throwable t) {
            t.printStackTrace();
        }
        cursor.close();
    }
}

嗯,谢谢你的留言,但是RingtonePreference允许用户为你的应用程序选择一个铃声资源。它没有设置系统铃声。好的,可能是我错过了,但参考没有明确说明。我想知道如果应用程序不处理来电,人们会在应用程序中使用铃声做什么。在上述代码中与媒体内容提供商交互时,每次都会创建一个新条目。您可能希望跟踪正在生成的Uri,这样可以避免重新下载,并直接跳到
RingtoneManager
。这一行中的
main
是什么
Uri newUri=main.getContentResolver().insert(Uri,值)
我得到的新Uri为null为什么我不不不。请帮助我..我用
getApplicationContext()
代替
main
是正确的还是我可以用什么来解决这个问题..在Android L中工作很好。但它不能将
newUri
作为null。我看到以下异常
android.database.sqlite.SQLiteConstraintException:column\u数据不是唯一的
。我添加的任何音频文件都会发生这种情况。请在newUri getContentResolver()之前的代码行下方添加。删除(uri,MediaStore.MediaColumns.data+“=\”+ringtoneFile.getAbsolutePath()+“\”,空);这将帮助您从放置所有铃声的原始文件夹中设置铃声;你能告诉我为什么写这行吗。这里的globalapps是什么?我如何将其设置为默认铃声silent/none请帮助你需要一个Vidar的答案和your's here的组合,它应该在SD卡上已经存在文件时运行。如果我们有音频文件的id,我们可以使用它,Uri;if(指向文件.startsWith(“/system”){uri=uri.parse(MediaStore.Audio.Media.INTERNAL\u CONTENT\u uri.toString()+“/”+id);}else-uri=uri.parse(MediaStore.Audio.Media.EXTERNAL\u CONTENT\u uri.toString()+“/”+id);
  private void setRingtone(Context context, String path) {
    if (path == null) {
        return;
    }
    File file = new File(path);
    ContentValues contentValues = new ContentValues();
    contentValues.put(MediaStore.MediaColumns.DATA, file.getAbsolutePath());
    String filterName = path.substring(path.lastIndexOf("/") + 1);
    contentValues.put(MediaStore.MediaColumns.TITLE, filterName);
    contentValues.put(MediaStore.MediaColumns.MIME_TYPE, "audio/mp3");
    contentValues.put(MediaStore.MediaColumns.SIZE, file.length());
    contentValues.put(MediaStore.Audio.Media.IS_RINGTONE, true);
    Uri uri = MediaStore.Audio.Media.getContentUriForPath(path);
    Cursor cursor = context.getContentResolver().query(uri, null, MediaStore.MediaColumns.DATA + "=?", new String[]{path}, null);
    if (cursor != null && cursor.moveToFirst() && cursor.getCount() > 0) {
        String id = cursor.getString(0);
        contentValues.put(MediaStore.Audio.Media.IS_RINGTONE, true);
        context.getContentResolver().update(uri, contentValues, MediaStore.MediaColumns.DATA + "=?", new String[]{path});
        Uri newuri = ContentUris.withAppendedId(uri, Long.valueOf(id));
        try {
            RingtoneManager.setActualDefaultRingtoneUri(context, RingtoneManager.TYPE_RINGTONE, newuri);
            Toast.makeText(context, "Set as Ringtone Successfully.", Toast.LENGTH_SHORT).show();
        } catch (Throwable t) {
            t.printStackTrace();
        }
        cursor.close();
    }
}