Android с помощью jaudiotagger - PullRequest
       59

Android с помощью jaudiotagger

3 голосов
/ 23 февраля 2012

Я пытаюсь использовать jaudiotagger следующим образом, но он вылетает

Main app.java: import java.io.File;import java.io.IOException;

import org.jaudiotagger.audio.AudioFile;
import org.jaudiotagger.audio.AudioFileIO;
import org.jaudiotagger.audio.AudioHeader;
import org.jaudiotagger.audio.exceptions.CannotReadException;
import org.jaudiotagger.audio.exceptions.CannotWriteException;
import org.jaudiotagger.audio.exceptions.InvalidAudioFrameException;
import org.jaudiotagger.audio.exceptions.ReadOnlyFileException;
import org.jaudiotagger.tag.FieldDataInvalidException;
import org.jaudiotagger.tag.FieldKey;
import org.jaudiotagger.tag.KeyNotFoundException;
import org.jaudiotagger.tag.Tag;
import org.jaudiotagger.tag.TagException;

import android.app.Activity;
import android.os.Bundle;
import android.widget.TextView;
import android.widget.Toast;

public class App extends Activity {
    /** Called when the activity is first created. */


    private TextView txt1;
    private TextView txt2;
    private TextView txt3;
    private TextView txt4;
    private TextView txt5;
    private TextView txt6;
    private TextView txt7;
    private TextView txt8;
    private TextView txt9;






    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

       // try
        //{
        File mp3 = new File("/sdcard/test.mp3");
        AudioFile f = null;
        try {
            f = AudioFileIO.read(mp3);
        } catch (CannotReadException e) {
            // TODO Auto-generated catch block
            txt1.setText(e.toString());
        } catch (IOException e) {
            // TODO Auto-generated catch block
            txt1.setText(e.toString());
        } catch (TagException e) {
            // TODO Auto-generated catch block
            txt1.setText(e.toString());
        } catch (ReadOnlyFileException e) {
            // TODO Auto-generated catch block
            txt1.setText(e.toString());
        } catch (InvalidAudioFrameException e) {
            // TODO Auto-generated catch block
            txt1.setText(e.toString());
        }
        Tag tag = f.getTag();
        AudioHeader AudioHeader = f.getAudioHeader();
        txt1.setText(tag.getFirst(FieldKey.ARTIST));
        txt2.setText(tag.getFirst(FieldKey.ALBUM));
        txt3.setText(tag.getFirst(FieldKey.TITLE));
        txt4.setText(tag.getFirst(FieldKey.COMMENT));
        txt5.setText(tag.getFirst(FieldKey.YEAR));
        txt6.setText(tag.getFirst(FieldKey.TRACK));
        txt7.setText(tag.getFirst(FieldKey.DISC_NO));
        txt8.setText(tag.getFirst(FieldKey.COMPOSER));
        txt9.setText(tag.getFirst(FieldKey.ARTIST_SORT));




        try {
            tag.setField(FieldKey.ARTIST,"Kings of Leon");
        } catch (KeyNotFoundException e) {
            // TODO Auto-generated catch block
            txt1.setText(e.toString());
        } catch (FieldDataInvalidException e) {
            // TODO Auto-generated catch block
            txt1.setText(e.toString());
        }
        try {
            AudioFileIO.write(f);
        } catch (CannotWriteException e) {
            txt1.setText(e.toString());
        }
       /* }
        catch(Exception x)
        {
            txt1.setText(x.toString());
        }
        */




    }
}

Logcat:

02-22 21: 12: 22.546: E / AndroidRuntime (19738): ИСКЛЮЧИТЕЛЬНОЕ ИСКЛЮЧЕНИЕ: главное 02-2221: 12: 22.546: E / AndroidRuntime (19738): java.lang.RuntimeException: невозможно запустить действие ComponentInfo {com.mp3.tag.editor.alexander.fuchs / com.mp3.tag.editor.alexander.fuchs.App}: java.lang.NullPointerException 02-22 21: 12: 22.546: E / AndroidRuntime (19738): на android.app.ActivityThread.performLaunchActivity (ActivityThread.java:1651) 02-22 21: 12: 22.546: E / AndroidRuntime(19738): в android.app.ActivityThread.handleLaunchActivity (ActivityThread.java:1667) 02-22 21: 12: 22.546: E / AndroidRuntime (19738): в android.app.ActivityThread.access $ 1500 (ActivityThread.java:117) 02-22 21: 12: 22.546: E / AndroidRuntime (19738): на android.app.ActivityThread $ H.handleMessage (ActivityThread.java:935) 02-22 21: 12: 22.546: E / AndroidRuntime (19738):на android.os.Handler.dispatchMessage (Handler.java:99) 02-22 21: 12: 22.546: E / AndroidRuntime (19738): на android.os.Looper.loop (Looper.java:130) 02-22 21: 12: 22.546: E / AndroidRuntime (19738): на android.app.ActivityThread.main (ActivityThread.java:3691) 02-22 21: 12: 22.546: E /AndroidRuntime (19738): на java.lang.reflect.Method.invokeNative (собственный метод) 02-22 21: 12: 22.546: E / AndroidRuntime (19738): на java.lang.reflect.Method.invoke (Method.java:507) 02-22 21: 12: 22.546: E / AndroidRuntime (19738): на com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run (ZygoteInit.java:907) 02-22 21: 12: 22.546: E /AndroidRuntime (19738): на com.android.internal.os.ZygoteInit.main (ZygoteInit.java:665) 02-22 21: 12: 22.546: E / AndroidRuntime (19738): на dalvik.system.NativeStart.main (нативныйМетод) 02-22 21: 12: 22.546: E / AndroidRuntime (19738): вызвано: java.lang.NullPointerException 02-22 21: 12: 22.546: E / AndroidRuntime (19738): на com.mp3.tag.editor.alexander.fuchs.App.onCreate (App.java:72) 02-22 21: 12: 22.546: E / AndroidRuntime (19738): на android.app.Instrumentation.callActivityOnCreate (Instrumentation.java:1047) 02-22 21: 12: 22.546: E / AndroidRuntime (19738): в android.app.ActivityThread.performLaunchActivity (ActivityThread.java:1615) 02-22 21: 12: 22.546: E / AndroidRuntime (19738): ... еще 11

Ответы [ 3 ]

2 голосов
/ 23 июня 2013

Там два блокатора использовать jaudiotagger на Android:

1 - javax.swing

2 - javax.imageio

эти два класса не поддерживаются android, и jaudiotagger использует их

Чтобы решить вашу проблему: Исправьте источники, чтобы они больше не зависели от этих двух классов JAVAX

1 голос
/ 23 февраля 2012

Похоже, эта строка вызывает сбой, потому что f имеет значение null:

Tag tag = f.getTag();

Не следует игнорировать исключение так, как вы это делаете, как если бы вы получили исключение, вы просто печатаете что-то и продолжаете работать с плохим состоянием (в этом случае - f по-прежнему равно нулю)

0 голосов
/ 03 марта 2013

Вам все еще нужно проверить, что f! = Null, прежде чем вы получите тег.

Tag r_tag = null;
File testFile = new File(filename);
MP3File f = null;
try {
    f = (MP3File)AudioFileIO.read(testFile);
} catch (CannotReadException e) {
    e.printStackTrace();
} catch (IOException e) {
    e.printStackTrace();
} catch (TagException e) {
    e.printStackTrace();
} catch (ReadOnlyFileException e) {
    e.printStackTrace();
} catch (InvalidAudioFrameException e) {
    e.printStackTrace();
}
if(f != null) {
    f.getTagOrCreateAndSetDefault();
    r_tag = f.getID3v2TagAsv24();
}
return r_tag;
...