内容:
1、准备工作
2、新建一个新闻的实体类News
3、新建布局文件news_content_frag.xml,作为新闻内容的布局
4、NewsContentFragment类,继承自Fragment
5、新建NewsContentActivity活动,将布局名指定为
news_content.xml
6、创建一个实现新闻列表的布局news_title_frag.xml
7、新建news_item.xml,作为RecyclerView子项的布局
8、新建展示新闻列表的碎片NewsTitleFragment
9、在NewsTitleFragment中新建一个内部类NewsAdapter来作为RecyclerView的适配器
10、修改NewsTitleFragment中的代码

一、准备工作
在app/build.gradle的dependencies中,加入以下一行代码

implementation 'androidx.recyclerview:recyclerview:1.1.0'

二、 新建一个新闻的实体类News

package com.example.fragmenttest;public class News {private String title;//新闻标题private String content;//新闻内容public String getTitle() {return title;}public void setTitle(String title) {this.title = title;}public String getContent() {return content;}public void setContent(String content) {this.content = content;}
}

三、新建布局文件news_content_frag.xml,作为双页模式下新闻内容部分的布局

在xml文件中设置android:visibility="invisible"
故在应用时,应将该设置修改为visible

<?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="match_parent"><!--新闻内容的布局分为两部分    --><LinearLayoutandroid:id="@+id/visiblity_layout"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"android:visibility="invisible"><!-- 1、头部部分:显示新闻标题  --><TextViewandroid:id="@+id/news_title"android:layout_width="match_parent"android:layout_height="wrap_content"android:gravity="center"android:padding="10dp"android:textSize="20sp"/><!-- 中间用一条黑线隔开  --><Viewandroid:layout_width="match_parent"android:layout_height="10dp"android:background="#000"/><!-- 2、正文部分:显示新闻内容        --><TextViewandroid:id="@+id/news_content"android:layout_width="match_parent"android:layout_height="0dp"android:layout_weight="1"android:padding="15dp"android:textSize="18sp" /></LinearLayout><Viewandroid:layout_width="match_parent"android:layout_height="1dp"android:layout_alignParentLeft="true"android:background="#000"/></RelativeLayout>

四、创建两种模式下共用新闻内容的Fragment:NewsContentFragment类,继承自Fragment

invisible修改为visible状态:
visibilityLayout.setVisibility(View.VISIBLE);

package com.example.fragmenttest;import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.fragment.app.Fragment;/*** NewsContentFragment类,继承自Fragment*/
public class NewsContentFragment extends Fragment{private View view;/*** * 加载刚创建好的news_content_frag布局* * @param inflater* @param container* @param savedInstanceState* @return*/@Nullable@Overridepublic View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {/*** resource : 它是要解析的XML文件的id号(必填)* root :   如果传入不为空, attachToRoot也为true, 就把XML解析后的view加入root子控件, 然后返回这个root.*          否则, 就返回一个解析之后的XML生成的view.* attachToRoot : 决定是否让root成为返回值的父控件**/view=inflater.inflate(R.layout.news_content_frag,container,false);return view;}/*** * 将新闻标题和新闻内容显示在界面上* * @param newsTitle* @param newsContent*/public void refresh(String newsTitle,String newsContent){View visibilityLayout=view.findViewById(R.id.visiblity_layout);visibilityLayout.setVisibility(View.VISIBLE);//分别获取到新闻标题和新闻内容的控件TextView newsTilteText=(TextView)view.findViewById(R.id.news_title);TextView newsContentText=(TextView)view.findViewById(R.id.news_content);//刷新新闻的标题和内容newsTilteText.setText(newsTitle);newsContentText.setText(newsContent);}
}

五、新建NewsContentActivity活动:单页模式下引用NewsContentFragment的Activity;
将布局名指定为news_content.xml:单页模式下新闻内容部分的布局

1、news_content.xml

充分发挥代码的复用性,在布局中直接引入NewsContentFragment
这样也相当于把news_content_frag布局的内容自动加了进来

android:name="com.example.fragmenttest.NewsContentFragment"

 <?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"><fragmentandroid:id="@+id/news_content_fragment"android:name="com.example.fragmenttest.NewsContentFragment"android:layout_width="match_parent"android:layout_height="match_parent"/></LinearLayout>

2、NewsContentActivity

package com.example.fragmenttest;import android.content.Context;
import android.content.Intent;
import android.os.Bundle;import androidx.appcompat.app.AppCompatActivity;/*** NewsContentActivity,继承自AppCompatActivity*/
public class NewsContentActivity extends AppCompatActivity {/*** 启动活动的最佳方法:无须阅读其他代码,就可以非常清晰的指导启动NewsContentActivity需要传递拿些数据* @param context* @param newsTitle* @param newsContent*/public static void actionStart(Context context, String newsTitle, String newsContent){Intent intent=new Intent(context,NewsContentActivity.class);intent.putExtra("news_title",newsTitle);intent.putExtra("news_content",newsContent);context.startActivity(intent);}/**** 通过Intent获取到了传入的新闻标题和新闻内容,然后调用FragmentManager的findFragmentById()方法* 得到 NewsContentFragment的实例,接着调用 NewsContentFragment 的 refresh()方法** @param savedInstanceState*/@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.news_content);//获取传入的新闻标题和新闻内容String newsTitle=getIntent().getStringExtra("news_title");String newsContent=getIntent().getStringExtra("news_content");NewsContentFragment  newsContentFragment=(NewsContentFragment)getSupportFragmentManager().findFragmentById(R.id.news_content_fragment);//将新闻标题和新闻内容显示在界面上newsContentFragment.refresh(newsTitle,newsContent);}
}

六、创建布局news_title_frag.xml:两种模式下共用新闻标题列表的布局

在这里用到了RecyclerView,那么就必定少不了子项的布局
之后会新建news_item.xml作为其子项布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:orientation="vertical"android:layout_width="match_parent"android:layout_height="match_parent"><androidx.recyclerview.widget.RecyclerViewandroid:id="@+id/news_title_recycler_view"android:layout_width="match_parent"android:layout_height="match_parent"/></LinearLayout>

七、新建布局news_item.xml:新闻标题列表的子布局(作为RecyclerView子项的布局)

设定当文本内容超出空间宽度时,文本的缩略方式,这里指定成end,表示在尾部进行缩略
android:ellipsize="end"

设置这个TextView只能单行显示
android:singleLine="true"

<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"android:orientation="vertical"android:id="@+id/news_title"android:layout_width="match_parent"android:layout_height="wrap_content"android:singleLine="true"android:ellipsize="end"android:textSize="18sp"android:paddingLeft="10dp"android:paddingRight="10dp"android:paddingTop="15dp"android:paddingBottom="15dp"></TextView>

八、新建NewsTitleFragment:两种模式下新闻标题部分的碎片

package com.example.fragmenttest;import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.fragment.app.Fragment;public class NewsTitleFragment extends Fragment {private boolean isTwoPage;@Nullable@Overridepublic View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {View view=inflater.inflate(R.layout.news_title_frag,container,false);return view;}@Overridepublic void onActivityCreated(@Nullable Bundle savedInstanceState) {super.onActivityCreated(savedInstanceState);if(getActivity().findViewById(R.id.news_content_layout)!=null){isTwoPage = true;}else{isTwoPage=false;}}
}

通过在活动中能否找到一个id为news_content_layout的View来判断当前是双页模式还是单页模式

因此,需要修改activity_main.xml的代码:单页模式下,只加载一个新闻标题的碎片布局

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"android:id="@+id/news_title_layout"android:layout_width="match_parent"android:layout_height="match_parent"><fragmentandroid:id="@+id/news_title_fragment"android:name="com.example.fragmenttest.NewsTitleFragment"android:layout_width="match_parent"android:layout_height="match_parent"/></FrameLayout>

通过限定符的方式系统区分运行的大屏幕还是小屏幕,新建适配大屏幕的布局文件夹layout-sw600dp,在其下创建activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:orientation="horizontal"android:layout_width="match_parent"android:layout_height="match_parent"><fragmentandroid:id="@+id/news_title_fragment"android:name="com.example.fragmenttest.NewsTitleFragment"android:layout_width="0dp"android:layout_height="match_parent"android:layout_weight="1"/><FrameLayoutandroid:id="@+id/news_content_layout"android:layout_width="0dp"android:layout_height="match_parent"android:layout_weight="3"><fragmentandroid:id="@+id/news_content_fragment"android:name="com.example.fragmenttest.NewsContentFragment"android:layout_width="match_parent"android:layout_height="match_parent"/></FrameLayout></LinearLayout>

九、在NewsTitleFragment中新建一个内部类NewsAdapter来作为RecyclerView的适配器

package com.example.fragmenttest;import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.fragment.app.Fragment;
import androidx.recyclerview.widget.RecyclerView;import java.util.List;public class NewsTitleFragment extends Fragment {private boolean isTwoPage;@Nullable@Overridepublic View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {View view=LayoutInflater.from(getContext()).inflate(R.layout.news_content_frag,container,false);return view;}@Overridepublic void onActivityCreated(@Nullable Bundle savedInstanceState) {super.onActivityCreated(savedInstanceState);if(getActivity().findViewById(R.id.news_content_layout)!=null){isTwoPage = true;}else{isTwoPage=false;}}class NewsAdapter extends RecyclerView.Adapter<NewsAdapter.ViewHolder>{private  List<News> mNewsList;public class ViewHolder extends RecyclerView.ViewHolder{TextView newsTitleText;public ViewHolder(@NonNull View itemView) {super(itemView);newsTitleText=(TextView) itemView.findViewById(R.id.news_title);}}public NewsAdapter(List<News> newsList){mNewsList = newsList;}@NonNull@Overridepublic ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {View view=LayoutInflater.from(parent.getContext()).inflate(R.layout.news_item,parent,false);final ViewHolder holder=new ViewHolder(view);view.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {News news=mNewsList.get(holder.getAdapterPosition());if(isTwoPage){//如果是双页模式,则刷新NewsContentFragment的内容NewsContentFragment newsContentFragment=(NewsContentFragment)getFragmentManager().findFragmentById(R.id.news_content_fragment);newsContentFragment.refresh(news.getTitle(),news.getContent());news.getContent();}else{//如果是单页模式,则直接启动NewsContentActivityNewsContentActivity.actionStart(getActivity(),news.getTitle(),news.getContent());}}});return holder;}@Overridepublic void onBindViewHolder(@NonNull ViewHolder holder, int position) {News news=mNewsList.get(position);holder.newsTitleText.setText(news.getTitle());}@Overridepublic int getItemCount() {return mNewsList.size();}}
}

十、修改NewsTitleFragment中的代码

1、修改onCreateView

 @Nullable@Overridepublic View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {View view=LayoutInflater.from(getContext()).inflate(R.layout.news_content_frag,container,false);RecyclerView newsTitleRecyclerView=(RecyclerView)view.findViewById(R.id.news_title_recycler_view);LinearLayoutManager layoutManager=new LinearLayoutManager(getActivity());newsTitleRecyclerView.setLayoutManager(layoutManager);NewsAdapter adapter=new NewsAdapter(getNews());newsTitleRecyclerView.setAdapter(adapter);return view;}

2、新增getNews

private List<News> getNews() {List<News> newsList=new ArrayList<>();for (int i = 0; i <=50 ; i++) {News news=new News();news.setTitle("This is news title "+i);news.setContent(getRandomLengthContent("This is news content "+i+"."));newsList.add(news);}return newsList;}

3、新增getRandomLengthContent

 private String getRandomLengthContent(String content) {Random random=new Random();int length=random.nextInt(20)+1;StringBuilder builder=new StringBuilder();for (int i = 0; i < length ; i++) {builder.append(content);}return builder.toString();}

十一、主活动MainActivity.java

public class MainActivity extends AppCompatActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);}
}

十二、运行效果

1、在手机上

[文件]

2、在平板上

Android之Fragment应用——一个简易版的新闻应用相关推荐

  1. 一个简易版的新闻应用(同时兼容手机和平板)

    代码可能有点长,需要耐心看几遍.前前后后我看了5遍才把整个流程吃透,相信你一定比我聪明!!! 新建一个FragmentBestPractice项目 (让ADT帮我们自动创建活动--活动名:MainAc ...

  2. 碎片的最佳实践——一个简易版的新闻应用

    现在你已经将关于碎片的重要知识点都掌握得差不多了,不过在灵活运用方面可能还有些欠缺,因此又该进入最佳实践环节了. 前面有提到过,碎片很多时候都是在平板开发当中使用的,主要是为了解决屏幕空间不能充分利用 ...

  3. DFiddler:A HTTP Packets Listener一个简易版的手机端的Fiddler。

    Diddler A HTTP Packets Listener一个简易版的手机端的Fiddler. Android系统需要Root权限. PIC_20140121_220503_617.jpeg PI ...

  4. 一个简易版的iphone电子书阅读器

    2019独角兽企业重金招聘Python工程师标准>>> 一个简易版的iphone电子书阅读器 里面的基本功能都有了 感兴趣的朋友可以下来研究 点击此处下载源码 转载:http://w ...

  5. 肝一波 ~ 手写一个简易版的Mybatis,带你深入领略它的魅力!

    零.准备工作 <dependencies><dependency><groupId>mysql</groupId><artifactId>m ...

  6. 实现一个简易版的微博,包含 client 和 server 两部分,并实现四个基础功能:关注、取关、发微博、获取用户微博列表

    const assert = require('assert'); const question = '实现一个简易版的微博,包含 client 和 server 两部分,并实现四个基础功能:关注.取 ...

  7. 依赖注入[5]: 创建一个简易版的DI框架[下篇]

    为了让读者朋友们能够对.NET Core DI框架的实现原理具有一个深刻而认识,我们采用与之类似的设计构架了一个名为Cat的DI框架.在<依赖注入[4]: 创建一个简易版的DI框架[上篇]> ...

  8. javascript实现图片轮播_手撸一个简易版轮播图(上)

    手撸一个简易版轮播图 实现原理,通过控制 swiper-warpper 容器的定位来达到切换图片的效果. 页面布局 简易版轮播图 < > 页面样式 .container{width: 60 ...

  9. 稳扎稳打Silverlight(18) - 2.0视频之详解MediaElement, 开发一个简易版的全功能播放器...

    [索引页] [×××] 稳扎稳打Silverlight(18) - 2.0视频之详解MediaElement, 开发一个简易版的全功能播放器 作者:webabcd 介绍 Silverlight 2.0 ...

最新文章

  1. ASP.NET上传文件管理控件
  2. 查看运行状态_查看 Linux 系统服务的 5 大方法
  3. 什么是“ 2的补码”?
  4. Quartz Properties 文件
  5. 数据仓库--基本概念
  6. 【转】用 PHP V5 开发多任务应用程序
  7. java读c二进制文件_如何使用JAVA读取C / Matlab创建的二进制文件
  8. python 图书馆管理程序下载_图书管理系统 免费开源代码 开发,分享 - CodeForge.cn...
  9. [PyTorch] 卷积函数 and 解卷积函数
  10. (转载)Sybase:bcp命令参考
  11. 肉肉好走,愿你在异界依旧快乐活泼
  12. 程序员的恶性循环:加班-没空学习-老是写同等水平代码-无法提升代码质量-老是出BUG-老是需要修改-加班-......
  13. 2019ZIF郑州工博会 盛大起航
  14. angularjs实现 - 增删改查+排序+敏感字(最终版)
  15. 2022年终Java编程技术总结
  16. Oracle 11G安装出错(Oracle执行先决条件检查失败)
  17. scrapy爬取表情包使用flask搭建搜索网站
  18. 如何用 IT 业者能听懂的话介绍量子计算的原理?
  19. 查看IC卡芯片的位置
  20. 【渝粤题库】陕西师范大学165205 组织设计与人力资源规划 作业(专升本)

热门文章

  1. 团队内的沟通方式:网络 OR 当面
  2. 【5G NR】NG接口
  3. Numpy:zero()函数
  4. JAVA计算机毕业设计宠物购物系统Mybatis+系统+数据库+调试部署
  5. 请使用“与 或 非” 逻辑符号实现“同或”、“异或”逻辑运算,简述实现方案并给出示意电路图。‏
  6. MySQL安全性机制
  7. 数据库为什么要分库分表
  8. 从代码层面分析STM32 标准库和HAL库的差异
  9. SAP 薪酬计算流程
  10. SAP 生产订单/工单状态说明