Tablayout + viewpager

第一步:    导依赖

                   

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();
    }
}







        

猜你喜欢

转载自blog.csdn.net/zh_binfgan/article/details/78012373