- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
首先我是一个新手,其次我知道有一个解决方案“如何从 android 中的专辑中获取歌曲?”但那是通过使用游标和 MediaStore 并且我使用了 MediametadataRetriever 并且它完全不同我没有使用 HashMap 和所有......所以它变得有点困难......请对此有任何解决方案吗???不使用 HashMap 和媒体存储区???
这是我用来显示所有歌曲及其艺术家的代码............
import java.io.File;
import java.io.FileFilter;
import java.io.FilenameFilter;
import java.io.Serializable;
import java.lang.reflect.Array;
import java.util.ArrayList;
import java.util.List;
import android.annotation.SuppressLint;
import android.content.Context;
import android.content.Intent;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.media.MediaMetadataRetriever;
import android.media.MediaPlayer;
import android.net.Uri;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.ListFragment;
import android.util.DisplayMetrics;
import android.util.TypedValue;
import android.view.ContextMenu;
import android.view.ContextMenu.ContextMenuInfo;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.AdapterView.AdapterContextMenuInfo;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ArrayAdapter;
import android.widget.ListView;
public class FragmentSongs extends Fragment implements Serializable {
AdapterView.AdapterContextMenuInfo info;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_song, container, false);
ListView SngList = (ListView) view.findViewById(R.id.SongList);
registerForContextMenu(SngList);
File f=new File("/sdcard/Music");
int j=0;int i=0;
final ArrayList<SongDetails> Songinfo = getSongsFromDirectory(f);
if (Songinfo.size()>0) {
for( j=0; j<Songinfo.size();j++) {
for ( i=j+1 ; i<Songinfo.size(); i++) {
SongDetails a=Songinfo.get(i);
SongDetails b=Songinfo.get(j);
if (a.getSong().toLowerCase().compareTo(b.getSong().toLowerCase()) < 0) {
Songinfo.set(i,b );
Songinfo.set(j,a);
}
}
}
SngList.setOnItemClickListener(new OnItemClickListener() {
public void onItemClick(AdapterView a, View v, int position, long id) {
Intent intent = new Intent(getActivity(), NowPlaying.class);
intent.putParcelableArrayListExtra("Data1",Songinfo);
intent.putExtra("Data2",position);
startActivity(intent);
}
});
SngList.setAdapter(new CustomAdapter(Songinfo));
return view;
} else {
return null;
}
}
public ArrayList<SongDetails> getSongsFromDirectory(File f) {
MediaMetadataRetriever mmr = new MediaMetadataRetriever();
ArrayList<SongDetails> songs = new ArrayList<SongDetails>();
Bitmap bitmap2;
Bitmap bmp = BitmapFactory.decodeResource(getResources(), R.drawable.ab);
float ht_px = TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 100, getResources().getDisplayMetrics());
float wt_px = TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, 100, getResources().getDisplayMetrics());
Bitmap bitmap3 = Bitmap.createScaledBitmap(bmp, (int) ht_px, (int) wt_px, true);
byte[] rawArt = null;
Bitmap art;
BitmapFactory.Options bfo=new BitmapFactory.Options();
if (!f.exists() || !f.isDirectory()) {
return songs;
}
File[] files = f.listFiles(new Mp3Filter());
for(int i=0; i<files.length; i++) {
if (files[i].isFile()) {
mmr.setDataSource(files[i].getPath());
rawArt = mmr.getEmbeddedPicture();
SongDetails detail=new SongDetails();
if ( rawArt != null) {
bitmap2=BitmapFactory.decodeByteArray(rawArt, 0, rawArt.length, bfo);
bitmap2 = Bitmap.createScaledBitmap(bitmap2, (int) ht_px, (int) wt_px, true);
detail.setIcon(bitmap2);
} else {
detail.setIcon(bitmap3);
}
detail.setSong(files[i].getName());
detail.setArtist(files[i].getName());
detail.setArtist( mmr.extractMetadata(MediaMetadataRetriever.METADATA_KEY_ARTIST));
detail.setAlbum( mmr.extractMetadata(MediaMetadataRetriever.METADATA_KEY_ALBUM));
detail.setPath2( files[i].getPath()) ;
songs.add(detail);
} else if (files[i].isDirectory()) {
songs.addAll(getSongsFromDirectory(files[i]));
}
}
return songs;
}
@Override
public void onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo) {
super.onCreateContextMenu(menu, v, menuInfo);
info = (AdapterContextMenuInfo) menuInfo;
menu.add(Menu.NONE, v.getId(), 0, "Play");
menu.add(Menu.NONE, v.getId(), 0, "Delete");
menu.add(Menu.NONE, v.getId(), 0, "Queue Item");
}
@Override
public boolean onContextItemSelected(MenuItem item) {
if (item.getTitle() == "Play") {
} else if (item.getTitle() == "Delete") {
} else if (item.getTitle() == "Queue Item") {
} else {
return false;
}
return true;
}
}
class Mp3Filter implements FileFilter {
public boolean accept(File file) {
return (file.isDirectory()||file.getName().endsWith(".mp3")|| file.getName().endsWith(".Mp3"));
}
}
最佳答案
查看本教程:
http://www.srikanthtechnologies.com/blog/android/audioplayer.aspx
您可以根据自己的需要稍微修改它:
private ArrayList<SongDeatils> getSongList(File musicFolder) {
ArrayList<SongDeatils> songs = new ArrayList<SongDeatils>();
for (File f : musicFolder.listFiles()) {
MediaMetadataRetriever md = new MediaMetadataRetriever();
md.setDataSource(musicFolder + "/" + f.getName());
// Assign variables like title, artist, etc
SongDeatils s = new SongDeatils();
s.setTitle(title);
s.setArtist(artist);
s.setSong(f.getPath());
// ...
songs.add(s);
}
return songs;
}
对于图像(封面)处理,它实际上应该在适配器中异步完成。我建议使用 Universal Image Loader .
更新:
刚看到你的评论。您真正想要的是一种无需使用文件过滤器和排序即可列出特定专辑或艺术家歌曲的有效方法。那么,唯一的其他选择是使用 MediaStore
/Cursor
。您可以构建不同类型的查询,具体取决于您尝试查看数据的方式。
因此,要查询艺术家列表,您可以使用 MediaStore.Audio.Artists.EXTERNAL_CONTENT_URI
并将艺术家姓名用作您的选择参数。
对于专辑列表,您现在拥有 ARTIST_KEY
,您可以使用它来查询 MediaStore.Audio.Artists.Albums.EXTERNAL_CONTENT_URI
,以获得专辑列表对于给定的艺术家。
有关如何列出给定艺术家的所有专辑的示例,请参阅 here .
关于android - 如何使用 MediametadataRetriever 从 android 中的专辑/艺术家获取歌曲?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18164413/
当我使用 extractMetadata( MediaMetadataRetriever.METADATA_KEY_TITLE ) 函数时。 部分返回的字符串显示不正确。 即 Christina Pe
我很难显示从流媒体源播放的当前轨道。使用 MediaMetaDataRetriever 类返回 NULL,表示失败。我写了一个简单的方法,但现在我倾向于认为这只适用于 MP3、WMA、AVI 等媒体文
可以用 String MediaMetadataRetriver.extractMetadata(int key); 与 key = MediaMetadataRetriver.METADATA_
我正在尝试找到一种将视频提取到帧中的方法。主要目标是使用 openGl 更改图像并重新构建视频。 问题是我找不到提取视频的合适方法。我看到使用 MediaMetadataRetriever 可以回答很
我目前正在使用 MediaMetadataRetriever 和 ImageView frame = videoFrame.getFrameAtTime(time, MediaMetadataRetr
好的,所以我正在尝试在我的应用程序中显示歌曲的专辑封面。我试图通过使用 Mediametadataretriever 来做到这一点。但是我在行 metaRetriver.setDataSource(E
我正在尝试为 Android 构建我自己的音乐播放器。 对于列表,我需要歌曲的元数据,所以我使用 MediaMetadataRetriever 来提取它们,但是检索器无法提取大多数歌曲的元数据(~63
我编写了一个简单的 Android 应用程序,它使用 MediaMetadataRetriver 类来获取帧。它工作正常,只是我意识到它会跳帧。 我要解码的视频 fragment 是用手机摄像头拍摄的
我对 MediaMetadataRetriever setdatasource 方法有疑问。我创建了一个简单的项目。 main.xml 只有一个 TextView ,它应该显示 music.mp3 的
我希望使用 MediaMetadataRetriever 在 5 秒视频上每秒检索 10 帧并将它们存储到 Arraylist 中。我对使用 ffmpeg 不感兴趣。 目前,我的应用程序正在创建 50
下面的代码只返回(test.gif)第一帧,并用5个相同的帧(视频第一帧)制作一个gif。 我在 StackOverflow 中阅读了大多数问题,但我无法弄清楚是什么原因导致了这个问题。 此外,根据一
我正在 android 上开发音乐播放器,但我遇到了一个错误,我不知道为什么。我认为我做对了,但行不通。 我确实搜索了很多 MediaMetadataRetriever,但我仍然看不出我的问题是什么。
有没有办法在 Android 中使用 MediaMetadataRetriever 获取 mp3/m4a 文件中嵌入章节的元数据?这仅适用于音频文件。我只需要获取章节名称、起始位置和持续时间。嵌入艺术
我正在尝试使用 Android MediaMetadataRetriever 获取 mp4 格式的录制视频的长度 - 但出现异常: 07-13 13:54:32.686: E/AndroidRunti
我想从我的媒体文件(主要是 mp3)中获取信息,但我只从我想要的那些值中获取 null。我已经尝试了 extractMetadata(key) 的所有键。我是否跳过/遗漏了什么? 代码基础: Medi
我已使用 MetadataRetriever 从视频中提取帧,并将所有图像存储在 ArrayList 中.我想将它们全部存储在 SD 卡上(仅用于测试目的)。 但是当我从模拟器中拉出一个文件夹并查看保
我的 MediaPlayer 正在工作,但我需要检索元数据,例如流标题。我正在使用此代码: public String getMeta(){ meta = new MediaMetad
我刚刚开始 android 开发。 我一直在尝试从我手机上的视频文件中提取帧,如下所示: MediaMetadataRetriever retriever = new MediaMetadataRet
我正在开发一个使用 mediaMetadataRetriever.setDataSource 抓取视频帧的应用程序。但是,当我设置视频路径时,它给了我一个非法参数异常并崩溃。我是 java 和 And
我正在尝试通过 URL 获取流媒体视频的第一帧。 getFrameAtTime 似乎总是无异常地返回 null。 @Override protected Bitmap
我是一名优秀的程序员,十分优秀!