Tablayout + viewpager

来源:互联网 发布:男友那个很大 知乎 编辑:程序博客网 时间:2024/06/06 18:00

第一步:    导依赖

                   

compile "com.android.support:design:24.1.1"

 第二步  布局

   

 <android.support.design.widget.TabLayout        android:id="@+id/tabLayout"        android:layout_width="match_parent"        android:layout_height="60dp"        app:tabBackground="@color/colorPrimary"        app:tabGravity="center"        app:tabIndicatorColor="@android:color/holo_orange_light"        app:tabIndicatorHeight="4dp"        app:tabMode="scrollable"        app:tabSelectedTextColor="@android:color/holo_orange_light"        app:tabTextColor="@color/colorAccent">    </android.support.design.widget.TabLayout>    <android.support.v4.view.ViewPager        android:layout_below="@+id/tabLayout"        android:id="@+id/vp"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        ></android.support.v4.view.ViewPager>

     第三步: main 里逻辑编程

          

public class MainActivity extends AppCompatActivity {    private  TabLayout a;    private List<String> list;    private ViewPager vp;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        a= (TabLayout) findViewById(R.id.tabLayout);        vp= (ViewPager) findViewById(R.id.vp);        list=new ArrayList<>();        list.add("头条");        list.add("社会");        list.add("国内");        list.add("国际");        list.add("娱乐");        list.add("体育");        list.add("军事");        list.add("科技");        list.add("财经");        list.add("时尚");        vp.setAdapter(new FragmentPagerAdapter(getSupportFragmentManager()) {                @Override            public CharSequence getPageTitle(int position) {                return list.get(position);            }            @Override            public Fragment getItem(int position) {                NewsFragment ooopp = new NewsFragment();                Bundle bundle = new Bundle();                if (list.get(position).equals("头条")){                    //fragment = new TouTiaoFragment();                    bundle.putString("name","top");                }else if (list.get(position).equals("社会")){                    bundle.putString("name","shehui");                }else if (list.get(position).equals("国内")){                    bundle.putString("name","guonei");                }else if (list.get(position).equals("国际")){                    bundle.putString("name","guoji");                }else if (list.get(position).equals("娱乐")){                    bundle.putString("name","yule");                }else if (list.get(position).equals("体育")){                    bundle.putString("name","tiyu");                }else if (list.get(position).equals("军事")){                    bundle.putString("name","junshi");                }else if (list.get(position).equals("科技")){                    bundle.putString("name","keji");                }else if (list.get(position).equals("财经")){                    bundle.putString("name","caijing");                }else if (list.get(position).equals("时尚")){                    bundle.putString("name","shishang");                }                ooopp.setArguments(bundle);                return ooopp;            }            @Override            public int getCount() {                return list.size();            }        });       a.setupWithViewPager(vp);    }

   第四步:创建NewsFragment类继承Fragment


package com.example.tadloyout;import android.os.Bundle;import android.os.Handler;import android.os.Message;import android.util.Log;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.widget.ListView;import com.google.gson.Gson;import android.support.v4.app.Fragment;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;import java.net.HttpURLConnection;import java.net.MalformedURLException;import java.net.ProtocolException;import java.net.URL;import java.util.List;/** * Created by lenovo on 2017/9/13. */public class NewsFragment extends Fragment{    private Handler handler=new Handler(){        @Override        public void handleMessage(Message msg) {            super.handleMessage(msg);            if(msg.what==0){                DataDataBean dataBean= (DataDataBean) msg.obj;                data = dataBean.getResult().getData();                Log.i("pppp",data.toString());                MyAdapter myAdapter=new MyAdapter(getActivity(),data);                lv.setAdapter(myAdapter);            }        }    };    private ListView lv;    private List<DataDataBean.ResultBean.DataBean> data;    @Override    public View onCreateView(LayoutInflater inflater,  ViewGroup container, Bundle savedInstanceState) {       View view=inflater.inflate(R.layout.item,container,false);        lv = (ListView) view.findViewById(R.id.lv);        Bundle bundle = getArguments();        String string = bundle.getString("name", "top");        getDataFromNet(string);        return view;    }    //请求网络数据    private void getDataFromNet(final String string) {        new Thread(){            @Override            public void run() {                String path = "http://v.juhe.cn/toutiao/index?type="+string+"&key=597b4f9dcb50e051fd725a9ec54d6653";                Log.i("pppp",path);                try {                    URL url=new URL(path);                    HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();                    urlConnection.setRequestMethod("GET");                    urlConnection.setReadTimeout(5000);                    urlConnection.setConnectTimeout(5000);                    int responseCode = urlConnection.getResponseCode();                    if (responseCode == 200){                        Log.i("pppp",responseCode+"");                        InputStream inputStream = urlConnection.getInputStream();                        String json = streamToString(inputStream,"utf-8");                        Log.i("pppp",json);                        Gson gson=new Gson();                        DataDataBean fromJson = gson.fromJson(json, DataDataBean.class);                        Message message=Message.obtain();                        message.what=0;                        message.obj=fromJson;                        handler.sendMessage(message);                    }                } catch (MalformedURLException e) {                    e.printStackTrace();                } catch (ProtocolException e) {                    e.printStackTrace();                } catch (IOException e) {                    e.printStackTrace();                }                super.run();            }        }.start();    }    private String streamToString(InputStream inputStream, String s) {        try {            InputStreamReader inputStreamReader = new InputStreamReader(inputStream, s);            BufferedReader bufferedReader = new BufferedReader(inputStreamReader);            StringBuilder builder = new StringBuilder();            String f=null;            while((f=bufferedReader.readLine())!=null){                builder.append(f);            }            bufferedReader.close();            return builder.toString();        } catch (Exception e) {            e.printStackTrace();        }        return null;    }}


    item

<?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">    <ListView        android:layout_width="match_parent"        android:layout_height="match_parent"    android:id="@+id/lv"></ListView></LinearLayout>


第五步:创建适配器MyAdapter类


package com.example.tadloyout;import android.app.Activity;import android.content.Context;import android.util.Log;import android.view.View;import android.view.ViewGroup;import android.widget.BaseAdapter;import android.widget.ImageView;import android.widget.TextView;import com.nostra13.universalimageloader.core.DisplayImageOptions;import com.nostra13.universalimageloader.core.ImageLoader;import com.nostra13.universalimageloader.core.display.RoundedBitmapDisplayer;import java.util.List;/** * Created by lenovo on 2017/9/13. */class MyAdapter extends BaseAdapter{    Context context;    List<DataDataBean.ResultBean.DataBean> data;    public MyAdapter(Context context, List<DataDataBean.ResultBean.DataBean> data) {        this.context = context;        this.data = data;    }    @Override    public int getCount() {        return data.size();    }    @Override    public Object getItem(int i) {        return data.get(i);    }    @Override    public long getItemId(int i) {        return i;    }    @Override    public View getView(int i, View view, ViewGroup viewGroup) {        Asd asd=null;        if (view==null){            Log.i("pppp","aaaaa"+data.toString());            view = View.inflate(context, R.layout.item2, null);            asd = new Asd();            asd.tv=view.findViewById(R.id.tv);            asd.img=view.findViewById(R.id.img);           view.setTag(asd);        }else{            asd= (Asd) view.getTag();        }        asd.tv.setText(data.get(i).getTitle());        Log.d("pppp",data.get(i).getTitle());        DisplayImageOptions options = new DisplayImageOptions.Builder()                .showImageOnLoading(R.mipmap.ic_launcher)            //加载图片时的图片                .showImageForEmptyUri(R.mipmap.ic_launcher)         //没有图片资源时的默认图片                .showImageOnFail(R.mipmap.ic_launcher)              //加载失败时的图片                .cacheInMemory(true)                               //启用内存缓存                .cacheOnDisk(true)                                 //启用外存缓存                .considerExifParams(true)                          //启用EXIF和JPEG图像格式                .displayer(new RoundedBitmapDisplayer(20))         //设置显示风格这里是圆角矩形                .build();         ImageLoader.getInstance().displayImage(data.get(i).getThumbnail_pic_s(),asd.img,options);        return view;    }    class Asd{        TextView tv;        ImageView img;    }}

item2

<?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"    >    <TextView        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:id="@+id/tv"        />    <ImageView        android:id="@+id/img"        android:layout_width="100dp"        android:layout_height="100dp"        android:layout_below="@+id/tv"        android:layout_alignParentLeft="true"        android:layout_alignParentStart="true" /></RelativeLayout>

创建MyApplic继承Application    加载图片工具类

package com.example.tadloyout;import android.app.Application;import android.content.Context;import android.content.res.Configuration;import android.os.Environment;import com.nostra13.universalimageloader.cache.disc.naming.Md5FileNameGenerator;import com.nostra13.universalimageloader.core.ImageLoader;import com.nostra13.universalimageloader.core.ImageLoaderConfiguration;import com.nostra13.universalimageloader.core.assist.QueueProcessingType;import java.io.File;import static android.R.attr.path;public class MyApplic extends Application{    @Override    public void onCreate() {        super.onCreate();        //初始化IamgeLoader        //获取sd卡根目录路径        File files = new File("/sdcard/Rimg");        initImageLoader(getApplicationContext(),files);    }    public static void initImageLoader(Context context,File file) {        ImageLoaderConfiguration.Builder config = new ImageLoaderConfiguration.Builder(context);        config.threadPriority(Thread.NORM_PRIORITY - 2);        config.denyCacheImageMultipleSizesInMemory();        config.diskCacheFileNameGenerator(new Md5FileNameGenerator());        config.diskCacheSize(50 * 1024 * 1024); // 50 MiB        config.tasksProcessingOrder(QueueProcessingType.LIFO);        config.writeDebugLogs(); // Remove for release app        config .diskCacheFileCount(50);//配置sdcard缓存文件的数量        // Initialize ImageLoader with configuration.        ImageLoader.getInstance().init(config.build());    }    @Override    public void onConfigurationChanged(Configuration newConfig) {        super.onConfigurationChanged(newConfig);    }    @Override    public void onLowMemory() {        super.onLowMemory();    }}







        

原创粉丝点击