我正在为 android 制作音乐播放器。除了包含 300 多首歌曲的列表视图外,一切都很完美!具有该列表视图的活动大约需要 5 秒才能加载,我想将这段时间减少到用户可接受的体验。基本上我只是使用歌曲标题和艺术家作为列表视图格式并且没有图像,但体验仍然很慢。谷歌搜索了很多,最终得到了延迟加载位图和平滑滚动文档,但没有关于列表视图活动的加载时间。这是我正在使用的代码 -
public View getView(int position, View convertView, ViewGroup parent) {
View vi = convertView;
ViewHolder holder;
if(convertView==null){
vi = inflater.inflate(R.layout.row, null);
holder = new ViewHolder();
holder.text = (TextView) vi.findViewById(R.id.text);
holder.text1=(TextView) vi.findViewById(R.id.text1);
vi.setTag( holder );
}
else {
holder=(ViewHolder)vi.getTag();
}
if(data.size()<=0)
{
holder.text.setText("No Data");
}
else
{
tempValues=null;
tempValues = ( ListModel ) data.get( position );
holder.text.setText( tempValues.getCompanyName() );
if (tempValues.getUrl()== null){
holder.text1.setText("Unknown Artist");
}
else {
holder.text1.setText( tempValues.getUrl() );
}
vi.setOnClickListener(new OnItemClickListener( position ));
}
return vi;
}
另一件事是当我打开列表视图活动三次或更多(如果幸运的话)它会崩溃(可能是内存原因但不确定)。这是原木猫
12-26 01:13:59.950: V/MediaPlayer-JNI(6349): getCurrentPosition: 68586 (msec)
12-26 01:13:59.960: V/MediaPlayer-JNI(6349): getCurrentPosition: 68586 (msec)
12-26 01:13:59.960: V/MediaPlayer-JNI(6349): isPlaying: 1
12-26 01:13:59.960: V/MediaPlayer-JNI(6349): getCurrentPosition: 68586 (msec)
12-26 01:14:00.020: D/AbsListView(6349): Get MotionRecognitionManager
12-26 01:14:01.392: D/AndroidRuntime(6349): Shutting down VM
12-26 01:14:01.392: W/dalvikvm(6349): threadid=1: thread exiting with uncaught exception (group=0x419aada0)
12-26 01:14:01.392: E/AndroidRuntime(6349): FATAL EXCEPTION: main
12-26 01:14:01.392: E/AndroidRuntime(6349): Process: com.garaya.musicplayer, PID: 6349
12-26 01:14:01.392: E/AndroidRuntime(6349): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.garaya.musicplayer/com.garaya.musicplayer.MainActivity}: java.lang.RuntimeException: setDataSource failed: status = 0x80000000
12-26 01:14:01.392: E/AndroidRuntime(6349): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2412)
12-26 01:14:01.392: E/AndroidRuntime(6349): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2470)
12-26 01:14:01.392: E/AndroidRuntime(6349): at android.app.ActivityThread.access$900(ActivityThread.java:174)
12-26 01:14:01.392: E/AndroidRuntime(6349): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1307)
12-26 01:14:01.392: E/AndroidRuntime(6349): at android.os.Handler.dispatchMessage(Handler.java:102)
12-26 01:14:01.392: E/AndroidRuntime(6349): at android.os.Looper.loop(Looper.java:146)
12-26 01:14:01.392: E/AndroidRuntime(6349): at android.app.ActivityThread.main(ActivityThread.java:5593)
12-26 01:14:01.392: E/AndroidRuntime(6349): at java.lang.reflect.Method.invokeNative(Native Method)
12-26 01:14:01.392: E/AndroidRuntime(6349): at java.lang.reflect.Method.invoke(Method.java:515)
12-26 01:14:01.392: E/AndroidRuntime(6349): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1283)
12-26 01:14:01.392: E/AndroidRuntime(6349): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1099)
12-26 01:14:01.392: E/AndroidRuntime(6349): at dalvik.system.NativeStart.main(Native Method)
12-26 01:14:01.392: E/AndroidRuntime(6349): Caused by: java.lang.RuntimeException: setDataSource failed: status = 0x80000000
12-26 01:14:01.392: E/AndroidRuntime(6349): at android.media.MediaMetadataRetriever.setDataSource(Native Method)
12-26 01:14:01.392: E/AndroidRuntime(6349): at android.media.MediaMetadataRetriever.setDataSource(MediaMetadataRetriever.java:70)
12-26 01:14:01.392: E/AndroidRuntime(6349): at com.garaya.musicplayer.MainActivity.setListData(MainActivity.java:241)
12-26 01:14:01.392: E/AndroidRuntime(6349): at com.garaya.musicplayer.MainActivity.onCreate(MainActivity.java:186)
12-26 01:14:01.392: E/AndroidRuntime(6349): at android.app.Activity.performCreate(Activity.java:5458)
12-26 01:14:01.392: E/AndroidRuntime(6349): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1093)
12-26 01:14:01.392: E/AndroidRuntime(6349): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2376)
12-26 01:14:01.392: E/AndroidRuntime(6349): ... 11 more
这是主要活动setListData()
-
public void setListData()
{
for(int i=0; i < files.length; i++)
{
File file = files[i];
final ListModel sched = new ListModel();
MediaMetadataRetriever metaRetriver;
metaRetriver = new MediaMetadataRetriever();
metaRetriver.setDataSource(file.getPath());
String filename = file.getName().replace(".mp3", "");
filename = filename.replace(".MP3", "");
String TitleFile = metaRetriver
.extractMetadata(MediaMetadataRetriever.METADATA_KEY_TITLE);
String finalName;
if (TitleFile == null || TitleFile == "") {
finalName = filename;
}
else {
finalName = TitleFile;
}
sched.setCompanyName(finalName);
sched.setUrl(metaRetriver
.extractMetadata(MediaMetadataRetriever.METADATA_KEY_ARTIST));
CustomListViewValuesArr.add( sched );
}
}
谷歌充斥着图像加载和无限列表视图加载,但列表视图加载时间没有很好的结果。我想异步可能会有所帮助,但我只是 android 的初学者,它是我第一个学习如何制作应用程序的 android 应用程序。所以,伙计们,请帮帮我!我很无知。(如果需要任何其他代码,请告诉我!)
没有 MetaDataRetriever 的已编辑 setListData() 在 2 秒内加载活动
public void setListData()
{
for(int i=0; i < files.length; i++)
{
File file = files[i];
final ListModel sched = new ListModel();
String filename = file.getName().replace(".mp3", "");
filename = filename.replace(".MP3", "");
sched.setCompanyName(filename);
sched.setUrl("Artist");
CustomListViewValuesArr.add( sched );
}
}