Android studio 音乐列表布局

时间: 2024-05-09 14:20:51 浏览: 9
在Android Studio中,可以使用ListView或RecyclerView来实现音乐列表布局。 ListView布局: 1. 创建一个ListView控件 ``` <ListView android:id="@+id/listView" android:layout_width="match_parent" android:layout_height="match_parent" android:divider="@null" android:dividerHeight="0dp" /> ``` 2. 创建一个自定义的列表项布局 ``` <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" android:padding="16dp"> <ImageView android:id="@+id/imageView" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/music_icon" /> <TextView android:id="@+id/textViewTitle" android:layout_width="0dp" android:layout_weight="1" android:layout_height="wrap_content" android:text="Song Title" android:textSize="18sp" android:textStyle="bold" /> <TextView android:id="@+id/textViewArtist" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Artist" android:textSize="16sp" /> </LinearLayout> ``` 3. 在代码中设置适配器和数据源 ``` ListView listView = findViewById(R.id.listView); List<Song> songs = new ArrayList<>(); // 添加歌曲数据 songs.add(new Song("Song 1", "Artist 1", R.drawable.music_icon)); songs.add(new Song("Song 2", "Artist 2", R.drawable.music_icon)); songs.add(new Song("Song 3", "Artist 3", R.drawable.music_icon)); // 创建适配器 SongAdapter adapter = new SongAdapter(this, songs); // 设置适配器 listView.setAdapter(adapter); ``` 4. 创建一个自定义的适配器 ``` public class SongAdapter extends ArrayAdapter<Song> { private Context mContext; private List<Song> mSongs; public SongAdapter(Context context, List<Song> songs) { super(context, 0, songs); mContext = context; mSongs = songs; } @NonNull @Override public View getView(int position, @Nullable View convertView, @NonNull ViewGroup parent) { View listItem = convertView; if (listItem == null) { listItem = LayoutInflater.from(mContext).inflate(R.layout.list_item_song, parent, false); } Song song = mSongs.get(position); ImageView imageView = listItem.findViewById(R.id.imageView); imageView.setImageResource(song.getImageResource()); TextView textViewTitle = listItem.findViewById(R.id.textViewTitle); textViewTitle.setText(song.getTitle()); TextView textViewArtist = listItem.findViewById(R.id.textViewArtist); textViewArtist.setText(song.getArtist()); return listItem; } } ``` RecyclerView布局: 1. 创建一个RecyclerView控件 ``` <androidx.recyclerview.widget.RecyclerView android:id="@+id/recyclerView" android:layout_width="match_parent" android:layout_height="match_parent" android:divider="@null" android:dividerHeight="0dp" /> ``` 2. 创建一个自定义的列表项布局(与ListView相同) ``` <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal" android:padding="16dp"> <ImageView android:id="@+id/imageView" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/music_icon" /> <TextView android:id="@+id/textViewTitle" android:layout_width="0dp" android:layout_weight="1" android:layout_height="wrap_content" android:text="Song Title" android:textSize="18sp" android:textStyle="bold" /> <TextView android:id="@+id/textViewArtist" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Artist" android:textSize="16sp" /> </LinearLayout> ``` 3. 在代码中设置适配器和数据源(与ListView相同) ``` RecyclerView recyclerView = findViewById(R.id.recyclerView); List<Song> songs = new ArrayList<>(); // 添加歌曲数据 songs.add(new Song("Song 1", "Artist 1", R.drawable.music_icon)); songs.add(new Song("Song 2", "Artist 2", R.drawable.music_icon)); songs.add(new Song("Song 3", "Artist 3", R.drawable.music_icon)); // 创建适配器 SongAdapter adapter = new SongAdapter(this, songs); // 设置适配器 recyclerView.setAdapter(adapter); ``` 4. 创建一个自定义的适配器(与ListView相同,只需将继承类从ArrayAdapter改为RecyclerView.Adapter) ``` public class SongAdapter extends RecyclerView.Adapter<SongAdapter.ViewHolder> { private Context mContext; private List<Song> mSongs; public SongAdapter(Context context, List<Song> songs) { mContext = context; mSongs = songs; } @NonNull @Override public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { View view = LayoutInflater.from(mContext).inflate(R.layout.list_item_song, parent, false); return new ViewHolder(view); } @Override public void onBindViewHolder(@NonNull ViewHolder holder, int position) { Song song = mSongs.get(position); holder.imageView.setImageResource(song.getImageResource()); holder.textViewTitle.setText(song.getTitle()); holder.textViewArtist.setText(song.getArtist()); } @Override public int getItemCount() { return mSongs.size(); } public class ViewHolder extends RecyclerView.ViewHolder { ImageView imageView; TextView textViewTitle; TextView textViewArtist; public ViewHolder(@NonNull View itemView) { super(itemView); imageView = itemView.findViewById(R.id.imageView); textViewTitle = itemView.findViewById(R.id.textViewTitle); textViewArtist = itemView.findViewById(R.id.textViewArtist); } } } ```

相关推荐

最新推荐

recommend-type

Android Studio实现简易计算器(表格布局TableLayout)

主要为大家详细介绍了Android Studio实现简易计算器,表格布局TableLayout,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

Android Studio 实现九宫格功能

主要介绍了Android Studio 实现九宫格,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
recommend-type

Android布局之GridLayout网格布局

网格布局标签是GridLayout。这个布局是android4.0新增的布局。这个布局只有4.0之后的版本才能使用。本文给大家介绍Android布局之GridLayout网格布局相关知识,感兴趣的朋友一起学习吧
recommend-type

Android代码实现图片和文字上下布局

在Android开发中经常会需要用到带文字和图片的button,下面来给大家介绍使用radiobutton实现图片和文字上下布局或左右布局。感兴趣的朋友一起学习吧
recommend-type

Android中实现布局背景模糊化处理的方法

主要介绍了Android中实现布局背景模糊化处理的方法,需要的朋友可以参考下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

用Spring boot和vue写一个登录注册界面

好的,这是一个比较常见的技术问题,我可以为您提供一些参考资料和思路。首先,您可以使用Spring Boot作为后端框架来处理用户认证和注册的逻辑,比如使用Spring Security实现用户登录认证。同时,您还需要设计相应的数据模型和数据库表结构来存储用户信息。在前端方面,您可以使用Vue.js作为框架来构建登录注册页面,使用Axios来发起API请求并和后端进行交互。当然,在实现过程中,还需要考虑一些具体细节,比如数据校验、安全性和用户体验等方面。希望这些信息能够帮助到您。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。