android studio实现顶部栏有四个图片加文字按键,代表四个分类,点击相应的图片可以切换不同类别的新闻列表,顶部栏存在于每个页面中,通过点击顶部栏进行切换页面;每个页面包含三条新闻,页面显示新闻的头像、时间、标题,新闻类的属性有头像ID、时间、标题和网址,点击页面中的新闻项通过intent跳转到手机自带浏览器进行阅览,给出详细代码

时间: 2023-06-12 08:08:03 浏览: 80
这里是一个简单的实现顶部栏有四个图片加文字按键,代表四个分类,点击相应的图片可以切换不同类别的新闻列表的 Android Studio 代码示例: 1. 首先在 `res/layout` 目录下创建 `activity_main.xml` 文件,用于显示顶部栏和新闻列表。 ``` <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/main_layout" android:layout_width="match_parent" android:layout_height="match_parent"> <!-- 顶部栏 --> <RelativeLayout android:id="@+id/top_bar" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@color/colorPrimary"> <ImageButton android:id="@+id/btn_category_1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentLeft="true" android:background="@null" android:src="@drawable/category1_icon" /> <ImageButton android:id="@+id/btn_category_2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_toRightOf="@id/btn_category_1" android:background="@null" android:src="@drawable/category2_icon" /> <ImageButton android:id="@+id/btn_category_3" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_toRightOf="@id/btn_category_2" android:background="@null" android:src="@drawable/category3_icon" /> <ImageButton android:id="@+id/btn_category_4" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_toRightOf="@id/btn_category_3" android:background="@null" android:src="@drawable/category4_icon" /> </RelativeLayout> <!-- 新闻列表 --> <ListView android:id="@+id/news_list" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_below="@id/top_bar" android:divider="@android:color/transparent" android:dividerHeight="10dp" android:listSelector="@android:color/transparent" /> </RelativeLayout> ``` 2. 在 `res/drawable` 目录下创建四个图片资源,分别代表四个分类的图标。 3. 在 `MainActivity.java` 中实现顶部栏的点击事件和新闻列表的显示。 ``` import android.content.Intent; import android.net.Uri; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.view.View; import android.widget.AdapterView; import android.widget.ImageButton; import android.widget.ListView; import java.util.ArrayList; import java.util.List; public class MainActivity extends AppCompatActivity { private ImageButton btnCategory1, btnCategory2, btnCategory3, btnCategory4; private ListView newsList; private List<News> newsData = new ArrayList<>(); private NewsAdapter newsAdapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 初始化控件 btnCategory1 = findViewById(R.id.btn_category_1); btnCategory2 = findViewById(R.id.btn_category_2); btnCategory3 = findViewById(R.id.btn_category_3); btnCategory4 = findViewById(R.id.btn_category_4); newsList = findViewById(R.id.news_list); // 设置顶部栏点击事件 btnCategory1.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 切换到分类1的新闻列表 loadNewsData("category1"); } }); btnCategory2.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 切换到分类2的新闻列表 loadNewsData("category2"); } }); btnCategory3.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 切换到分类3的新闻列表 loadNewsData("category3"); } }); btnCategory4.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 切换到分类4的新闻列表 loadNewsData("category4"); } }); // 初始化新闻列表 newsAdapter = new NewsAdapter(this, newsData); newsList.setAdapter(newsAdapter); newsList.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { // 跳转到浏览器查看新闻 News news = newsData.get(position); Intent intent = new Intent(Intent.ACTION_VIEW); intent.setData(Uri.parse(news.getUrl())); startActivity(intent); } }); } // 加载指定分类的新闻列表 private void loadNewsData(String category) { // TODO: 根据分类从网络或本地加载新闻数据 // 这里只是简单地模拟数据 newsData.clear(); for (int i = 0; i < 3; i++) { News news = new News(); news.setAvatarId(R.drawable.news_avatar); news.setTime("2022-01-01"); news.setTitle("新闻标题" + i); news.setUrl("http://www.example.com/news" + i + ".html"); newsData.add(news); } newsAdapter.notifyDataSetChanged(); } } ``` 4. 在 `News.java` 中定义新闻类。 ``` public class News { private int avatarId; private String time; private String title; private String url; public int getAvatarId() { return avatarId; } public void setAvatarId(int avatarId) { this.avatarId = avatarId; } public String getTime() { return time; } public void setTime(String time) { this.time = time; } public String getTitle() { return title; } public void setTitle(String title) { this.title = title; } public String getUrl() { return url; } public void setUrl(String url) { this.url = url; } } ``` 5. 在 `NewsAdapter.java` 中定义新闻列表的适配器。 ``` import android.content.Context; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.ImageView; import android.widget.TextView; import java.util.List; public class NewsAdapter extends BaseAdapter { private Context context; private List<News> newsList; public NewsAdapter(Context context, List<News> newsList) { this.context = context; this.newsList = newsList; } @Override public int getCount() { return newsList.size(); } @Override public Object getItem(int position) { return newsList.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder viewHolder; if (convertView == null) { convertView = LayoutInflater.from(context).inflate(R.layout.item_news, parent, false); viewHolder = new ViewHolder(); viewHolder.avatarView = convertView.findViewById(R.id.news_avatar); viewHolder.timeView = convertView.findViewById(R.id.news_time); viewHolder.titleView = convertView.findViewById(R.id.news_title); convertView.setTag(viewHolder); } else { viewHolder = (ViewHolder) convertView.getTag(); } News news = newsList.get(position); viewHolder.avatarView.setImageResource(news.getAvatarId()); viewHolder.timeView.setText(news.getTime()); viewHolder.titleView.setText(news.getTitle()); return convertView; } private static class ViewHolder { ImageView avatarView; TextView timeView; TextView titleView; } } ``` 6. 在 `res/layout` 目录下创建 `item_news.xml` 文件,定义新闻列表项的布局。 ``` <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="10dp"> <ImageView android:id="@+id/news_avatar" android:layout_width="60dp" android:layout_height="60dp" android:layout_alignParentLeft="true" android:src="@drawable/news_avatar" /> <TextView android:id="@+id/news_time" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_toRightOf="@id/news_avatar" android:layout_marginLeft="10dp" android:textColor="#888888" android:textSize="12sp" android:text="2022-01-01" /> <TextView android:id="@+id/news_title" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_toRightOf="@id/news_avatar" android:layout_below="@id/news_time" android:layout_marginLeft="10dp" android:textSize="16sp" android:text="新闻标题" /> </RelativeLayout> ``` 这样就完成了一个简单的实现顶部栏有四个图片加文字按键,代表四个分类,点击相应的图片可以切换不同类别的新闻列表的 Android Studio 代码示例。

相关推荐

最新推荐

recommend-type

Android自定义ImageView实现点击两张图片切换效果

主要为大家详细介绍了Android自定义ImageView实现点击两张图片切换效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

Android实现图片轮播切换实例代码

利用Android的ViewFlipper和AnimationUtils实现图片带有动画的轮播切换,其中当点击“上一张”图片时,切换到上一张图片;当点击“下一张”图片时,切换到下一张图片,本文给大家介绍Android实现图片轮播切换实例...
recommend-type

android listview实现新闻列表展示效果

主要为大家详细介绍了android listview实现新闻列表展示效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

Android studio listview实现列表数据显示 数据循环显示效果

主要介绍了Android studio listview实现列表数据显示 数据循环显示功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
recommend-type

详解android 视频图片混合轮播实现

主要介绍了android 视频图片混合轮播实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

RTL8188FU-Linux-v5.7.4.2-36687.20200602.tar(20765).gz

REALTEK 8188FTV 8188eus 8188etv linux驱动程序稳定版本, 支持AP,STA 以及AP+STA 共存模式。 稳定支持linux4.0以上内核。
recommend-type

管理建模和仿真的文件

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

:YOLOv1目标检测算法:实时目标检测的先驱,开启计算机视觉新篇章

![:YOLOv1目标检测算法:实时目标检测的先驱,开启计算机视觉新篇章](https://img-blog.csdnimg.cn/img_convert/69b98e1a619b1bb3c59cf98f4e397cd2.png) # 1. 目标检测算法概述 目标检测算法是一种计算机视觉技术,用于识别和定位图像或视频中的对象。它在各种应用中至关重要,例如自动驾驶、视频监控和医疗诊断。 目标检测算法通常分为两类:两阶段算法和单阶段算法。两阶段算法,如 R-CNN 和 Fast R-CNN,首先生成候选区域,然后对每个区域进行分类和边界框回归。单阶段算法,如 YOLO 和 SSD,一次性执行检
recommend-type

info-center source defatult

这是一个 Cisco IOS 命令,用于配置 Info Center 默认源。Info Center 是 Cisco 设备的日志记录和报告工具,可以用于收集和查看设备的事件、警报和错误信息。该命令用于配置 Info Center 默认源,即设备的默认日志记录和报告服务器。在命令行界面中输入该命令后,可以使用其他命令来配置默认源的 IP 地址、端口号和协议等参数。
recommend-type

c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf

校园超市商品信息管理系统课程设计旨在帮助学生深入理解程序设计的基础知识,同时锻炼他们的实际操作能力。通过设计和实现一个校园超市商品信息管理系统,学生掌握了如何利用计算机科学与技术知识解决实际问题的能力。在课程设计过程中,学生需要对超市商品和销售员的关系进行有效管理,使系统功能更全面、实用,从而提高用户体验和便利性。 学生在课程设计过程中展现了积极的学习态度和纪律,没有缺勤情况,演示过程流畅且作品具有很强的使用价值。设计报告完整详细,展现了对问题的深入思考和解决能力。在答辩环节中,学生能够自信地回答问题,展示出扎实的专业知识和逻辑思维能力。教师对学生的表现予以肯定,认为学生在课程设计中表现出色,值得称赞。 整个课程设计过程包括平时成绩、报告成绩和演示与答辩成绩三个部分,其中平时表现占比20%,报告成绩占比40%,演示与答辩成绩占比40%。通过这三个部分的综合评定,最终为学生总成绩提供参考。总评分以百分制计算,全面评估学生在课程设计中的各项表现,最终为学生提供综合评价和反馈意见。 通过校园超市商品信息管理系统课程设计,学生不仅提升了对程序设计基础知识的理解与应用能力,同时也增强了团队协作和沟通能力。这一过程旨在培养学生综合运用技术解决问题的能力,为其未来的专业发展打下坚实基础。学生在进行校园超市商品信息管理系统课程设计过程中,不仅获得了理论知识的提升,同时也锻炼了实践能力和创新思维,为其未来的职业发展奠定了坚实基础。 校园超市商品信息管理系统课程设计的目的在于促进学生对程序设计基础知识的深入理解与掌握,同时培养学生解决实际问题的能力。通过对系统功能和用户需求的全面考量,学生设计了一个实用、高效的校园超市商品信息管理系统,为用户提供了更便捷、更高效的管理和使用体验。 综上所述,校园超市商品信息管理系统课程设计是一项旨在提升学生综合能力和实践技能的重要教学活动。通过此次设计,学生不仅深化了对程序设计基础知识的理解,还培养了解决实际问题的能力和团队合作精神。这一过程将为学生未来的专业发展提供坚实基础,使其在实际工作中能够胜任更多挑战。