Настройка массива для сохранения звуков в приложении Android - PullRequest
0 голосов
/ 28 декабря 2011

Привет всем. Я уже давно смотрю вокруг и не могу найти ответ на свой вопрос. Я новичок в программировании для Android и изучил немного, но не очень много Java в колледже, но взял другие языки, чтобы понять концепции. Я спрашиваю, как я могу реализовать массив, который я создал в моей функции сохранения. Я думал, что знаю как, но просто передавая saveasRing(0), где мой массив содержит необработанное значение, но я получаю силу закрытия, поэтому я спрашиваю. Вот мой код.

Я не прошу, чтобы кто-то написал мой код, но объяснил мне, что делать ... Я хочу учиться и надеюсь, что просто что-то упускаю, но если нет, то, пожалуйста, ведите меня в правильном направлении. Спасибо!

String[] name ={ "a1", "a", "b","c"}; //code shortened
int[] sounds = {R.raw.a1, R.raw.a };  //code shortened for ease of reading

public void function1(int id){  // when I change int to int[] Eclipse wants me 
                                // to change alot of things and then the app will 
                                // force close on start
  saveasRing(sounds);           // right here I have tried passing "0" instead 
                                // of sounds, a no go.

  Toast.makeText(this, "Saved as Ringtone", Toast.LENGTH_SHORT).show();  
}//Closes Function 1  

//Save as Ringtone Coding for Function 3  
public boolean saveasRing(int ressound){  
  byte[] buffer=null;  
  InputStream fIn = getBaseContext().getResources().openRawResource(ressound);  
  int size=0;  

  try {  
    size = fIn.available();  
    buffer = new byte[size];  
    fIn.read(buffer);  
    fIn.close();  
  } 
  catch (IOException e) {  
    // TODO Auto-generated catch block  
    return false;  
  }  

  String path="/sdcard/media/audio/ringtones/";  
  String filename= name +".mp3";  

  boolean exists = (new File(path)).exists();  
  if (!exists){new File(path).mkdirs();  }  

  FileOutputStream save;  
  try {  
    save = new FileOutputStream(path+filename);  
    save.write(buffer);  
    save.flush();  
    save.close();  
  } 
  catch (FileNotFoundException e) {  
    // TODO Auto-generated catch block  
    return false;  
  } 
  catch (IOException e) {  
    // TODO Auto-generated catch block  
    return false;  
  }      

  sendBroadcast(new Intent(Intent.ACTION_MEDIA_SCANNER_SCAN_FILE,
                Uri.parse("file://"+path+filename)));  

  File k = new File(path, filename);  
  ContentValues values = new ContentValues();  
  values.put(MediaStore.MediaColumns.DATA, k.getAbsolutePath());  
  values.put(MediaStore.MediaColumns.TITLE, "dosequis");  
  values.put(MediaStore.MediaColumns.MIME_TYPE, "audio/mp3");  
  values.put(MediaStore.Audio.Media.ARTIST, "Most Interesting Man ");  
  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  
  this.getContentResolver().insert(MediaStore.Audio.Media.getContentUriForPath(k.getAbsolutePath()), values);  

  return true;  
}
//Closes Save as Ringtone 

Вот Logcat того, что происходит, когда я долго нажимаю на рингтон. Контекстное меню появляется нормально, только когда я выбираю тип для сохранения, когда получаю принудительное закрытие и эти ошибки. Спасибо за ваше время снова.

Пожалуйста, дайте мне знать, если есть лучший способ отформатировать это.

 W/ResourceType(225):No package identifier when getting name for resource number 0x00000000

D/AndroidRuntime(225):Shutting down VM

W/dalvikvm(225): threadid=3: thread exiting with uncaught exception (group=0x4001b188)

E/AndroidRuntime(225):Uncaught handler: thread main exiting due to uncaught exception

E/AndroidRuntime(225):android.content.res.Resources$NotFoundException: Resource ID #0x0

E/AndroidRuntime(225):at android.content.res.Resources.getValue(Resources.java:891)

E/AndroidRuntime(225):at Android.content.res.Resources.openRawResource(Resources.java:816)

E/AndroidRuntime(225):at android.content.res.Resources.openRawResource(Resources.java:798)

E/AndroidRuntime(225):at tomcavell.app.DosEquisSoundboardActivity.saveasRing(DosEquisSoundboardActivity.java:270)

E/AndroidRuntime(225):at tomcavell.app.DosEquisSoundboardActivity.function1(DosEquisSoundboardActivity.java:253)

E/AndroidRuntime(225):at tomcavell.app.DosEquisSoundboardActivity.onContextItemSelected(DosEquisSoundboardActivity.java:245)

E/AndroidRuntime(225):at android.app.Activity.onMenuItemSelected(Activity.java:2174)

E/AndroidRuntime(225):at com.android.internal.policy.impl.PhoneWindow$ContextMenuCallback.onMenuItemSelected(PhoneWindow.java:2731)

E/AndroidRuntime(225):at com.android.internal.view.menu.MenuItemImpl.invoke(MenuItemImpl.java:139)

E/AndroidRuntime(225):at com.android.internal.view.menu.MenuBuilder.performItemAction(MenuBuilder.java:855)

E/AndroidRuntime(225):at com.android.internal.view.menu.MenuDialogHelper.onClick(MenuDialogHelper.java:129)

E/AndroidRuntime(225):at com.android.internal.app.AlertController$AlertParams$3.onItemClick(AlertController.java:884)

E/AndroidRuntime(225):at android.widget.AdapterView.performItemClick(AdapterView.java:284)

E/AndroidRuntime(225):at android.widget.ListView.performItemClick(ListView.java:3285)

E/AndroidRuntime(225):at android.widget.AbsListView$PerformClick.run(AbsListView.java:1640)

E/AndroidRuntime(225):at android.os.Handler.handleCallback(Handler.java:587)

E/AndroidRuntime(225):at android.os.Handler.dispatchMessage(Handler.java:92)

E/AndroidRuntime(225):at android.os.Looper.loop(Looper.java:123)

E/AndroidRuntime(225):at android.app.ActivityThread.main(ActivityThread.java:4363)

E/AndroidRuntime(225):at java.lang.reflect.Method.invokeNative(Native Method)

E/AndroidRuntime(225):at java.lang.reflect.Method.invoke(Method.java:521)

E/AndroidRuntime(225):at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)

E/AndroidRuntime(225):at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)

E/AndroidRuntime(225):at dalvik.system.NativeStart.main(Native Method)

I/dalvikvm(225): threadid=7: reacting to signal 3

I/dalvikvm(225): Wrote stack trace to '/data/anr/traces.txt'

1 Ответ

0 голосов
/ 29 декабря 2011

Я понял, моя проблема.Мне пришлось установить код с помощью int, а затем установить его как

j=sounds[i]; //(assuming j was the int declared)

Затем передать функцию saveasRing с i, как в

saveasRing[i];

Спасибо за внимание и помощь!

...