使用ViewPager Handler 展示

//=============
1.判断网络
创建一个类


public class NetWorkUtils {
    public static boolean isNetWork(Context context){
        ConnectivityManager manager = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
        //得到网络信息
        NetworkInfo info = manager.getActiveNetworkInfo();
        if (info!=null){
            return info.isAvailable();
        }
        return false;
    }
}

2.回到主页面


public class MainActivity extends FragmentActivity {

    private ViewPager pager;
    private RadioGroup radioGroup;
    private RadioButton radio1;
    private RadioButton radio2;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        boolean b = NetWorkUtils.isNetWork(this);
        if(b){
            Toast.makeText(this, "有网", Toast.LENGTH_SHORT).show();
        }else{
            Toast.makeText(this, "现在没网", Toast.LENGTH_SHORT).show();
            AlertDialog.Builder builder = new AlertDialog.Builder(this);
            builder.setTitle("提示");
            builder.setMessage("设置网络连接");
            builder.setPositiveButton("确定", new DialogInterface.OnClickListener() {
                @Override
                public void onClick(DialogInterface dialog, int which) {

                }
            });
            builder.setNegativeButton("取消",null);
            builder.create().show();
        }


        pager = findViewById(R.id.pager);
        radioGroup = findViewById(R.id.radioGroup);
        radio1 = findViewById(R.id.radio1);
        radio2 = findViewById(R.id.radio2);

        final ArrayList<Fragment> list = new ArrayList<Fragment>();
        Frag01 frag01 = new Frag01();
        Frag02 frag02 = new Frag02();
        list.add(frag01);
        list.add(frag02);

        //默认选中第一个页面
        radioGroup.check(list.get(0).getId());
        //设置适配器
        pager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
            @Override
            public void onPageScrolled(int i, float v, int i1) {

            }

            @Override
            public void onPageSelected(int i) {
                    radioGroup.check(radioGroup.getChildAt(i).getId());
            }

            @Override
            public void onPageScrollStateChanged(int i) {

            }
        });
        pager.setAdapter(new FragmentPagerAdapter(getSupportFragmentManager()) {
            @Override
            public int getCount() {
                return list.size();
            }

            @Override
            public Fragment getItem(int i) {
                return list.get(i);
            }
        });
        radioGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {
            @Override
            public void onCheckedChanged(RadioGroup group, int checkedId) {
                switch (checkedId){
                    case R.id.radio1:
                        pager.setCurrentItem(0);
                        break;
                    case R.id.radio2:
                        pager.setCurrentItem(1);
                        break;
                }
            }
        });
    }
}

3.Fragment第一个页面

/*
1)首页 使用HttpClient进行网络请求,
加载网络数据,
使用Gson解析数据,
通过Handler更新UI ;
 */
public class Frag01 extends Fragment {
    private String path = "http://api.expoon.com/AppNews/getNewsList/type/1/p/1";
    private ListView listView;
    @SuppressLint("HandlerLeak")
    Handler handler = new Handler(){
        @Override
        public void handleMessage(Message msg) {
            super.handleMessage(msg);
            String json = (String) msg.obj;
            Gson gson = new Gson();
            JSON jsonBean = gson.fromJson(json, JSON.class);
            ArrayList<Datas> data = jsonBean.getData();
            listView.setAdapter(new ListAdapter(getActivity(),data));
        }
    };
    @Nullable
    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.frag01,container,false);
        listView = view.findViewById(R.id.listView);
        //========================
        ViewGroup parent = (ViewGroup) view.getParent();
        if(parent!=null){
            //移除多余视图
            parent.removeView(view);
        }
        //++++++++++++++=
        getData();
        return view;
    }

    private void getData() {
        new Thread(new Runnable() {
            @Override
            public void run() {
                //创建URL
                try {
                    URL url = new URL(path);
                    //打开连接
                    HttpURLConnection coon = (HttpURLConnection) url.openConnection();
                    //请求方式
                    coon.setRequestMethod("GET");
                    //pand状态码
                    if(coon.getResponseCode()==200){
                        InputStream inputStream = coon.getInputStream();
                        //创建字节输出流
                        ByteArrayOutputStream bos = new ByteArrayOutputStream();
                        byte[] buffer = new byte[1024];
                        int len =0;
                        while ((len=inputStream.read(buffer))!=-1){
                            bos.write(buffer,0,len);
                        }
                        //关流
                        inputStream.close();
                        bos.close();
                        String json = bos.toString();
                        Message message = Message.obtain();
                        message.obj=json;
                        message.what=0;
                        handler.sendMessage(message);
                    }

                } catch (Exception e) {
                    e.printStackTrace();
                }

            }
        }).start();
    }


}

4.第二个页面


public class Frag02 extends Fragment {
    private String path = "http://api.expoon.com/AppNews/getNewsList/type/1/p/1";
    private GridView gridView;

    @Nullable
    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.frag02,container,false);
        gridView = view.findViewById(R.id.gridView);
        //=========
        ViewGroup parent = (ViewGroup) view.getParent();
        if (parent!=null) {
            //移除多余视图
            parent.removeView(view);
        }
        //======================
        MyAsyncTask myAsyncTask = new MyAsyncTask();
        myAsyncTask.execute(path);
        return view;
    }

    private class MyAsyncTask extends AsyncTask<String,Integer,String> {
        @Override
        protected String doInBackground(String... parmas) {
            String uri = parmas[0];
            try {
                URL url = new URL(uri);
                HttpURLConnection conn = (HttpURLConnection) url.openConnection();
                conn.setRequestMethod("GET");
                conn.setConnectTimeout(5000);
                if(conn.getResponseCode()==200){
                    InputStream inputStream = conn.getInputStream();
                    ByteArrayOutputStream ao = new ByteArrayOutputStream();
                    byte[] buffer = new byte[1024];
                    int len =0;
                    while ((len=inputStream.read(buffer))!=-1){
                        ao.write(buffer,0,len);
                    }
                    inputStream.close();
                    ao.close();
                    String json = ao.toString();
                    return json;
                }
            } catch (Exception e) {
                e.printStackTrace();
            }

            return null;
        }
        //更新UI

        @Override
        protected void onPostExecute(String s) {
            super.onPostExecute(s);
            Log.i("xxx",s);
            Gson gson = new Gson();
            JSON fromJson = gson.fromJson(s, JSON.class);
            ArrayList<Datas> arrayList = fromJson.getData();
            gridView.setAdapter(new MyAdapter(arrayList,getActivity()));
        }
    }
}

5.分别给他们两个设置适配器

public class MyAdapter extends BaseAdapter {
    private ArrayList<Datas> list;
    private Context context;

    public MyAdapter(ArrayList<Datas> list, Context context) {
        this.list = list;
        this.context = context;
    }

    @Override
    public int getCount() {
        return list.size();
    }

    @Override
    public Object getItem(int position) {
        return null;
    }

    @Override
    public long getItemId(int position) {
        return 0;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        ViewHolder viewHolder;
        if(convertView==null){
            convertView = convertView.inflate(context, R.layout.gridview_layout,null);
            viewHolder = new ViewHolder();
            viewHolder.a = convertView.findViewById(R.id.grid);


            convertView.setTag(viewHolder);
        }else{
            viewHolder = (ViewHolder) convertView.getTag();
        }
        viewHolder.a.setText(list.get(position).getNews_title());
        return convertView;
    }
    class ViewHolder{
      TextView a;

    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用ViewPager实现轮播图的基本步骤: 1. 在布局文件中添加一个ViewPager和一个指示器(通常使用圆形的小点来表示)。 ```xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content"> <android.support.v4.view.ViewPager android:id="@+id/view_pager" android:layout_width="match_parent" android:layout_height="200dp"/> <LinearLayout android:id="@+id/indicator" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignBottom="@id/view_pager" android:layout_centerHorizontal="true" android:orientation="horizontal"/> </RelativeLayout> ``` 2. 创建一个PagerAdapter,并在其中实现getItem()和getCount()方法。getItem()方法返回一个Fragment,用于显示每一页的内容。 ```java public class MyPagerAdapter extends FragmentPagerAdapter { private List<Fragment> fragmentList; public MyPagerAdapter(FragmentManager fm, List<Fragment> fragmentList) { super(fm); this.fragmentList = fragmentList; } @Override public Fragment getItem(int position) { return fragmentList.get(position); } @Override public int getCount() { return fragmentList.size(); } } ``` 3. 在Activity或Fragment中,初始化ViewPager和指示器,并设置PagerAdapter和ViewPager的监听器。 ```java public class MainActivity extends AppCompatActivity { private ViewPager viewPager; private LinearLayout indicator; private List<Fragment> fragmentList; private MyPagerAdapter pagerAdapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); viewPager = (ViewPager) findViewById(R.id.view_pager); indicator = (LinearLayout) findViewById(R.id.indicator); fragmentList = new ArrayList<>(); fragmentList.add(new MyFragment(R.drawable.image1)); fragmentList.add(new MyFragment(R.drawable.image2)); fragmentList.add(new MyFragment(R.drawable.image3)); pagerAdapter = new MyPagerAdapter(getSupportFragmentManager(), fragmentList); viewPager.setAdapter(pagerAdapter); viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() { @Override public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { } @Override public void onPageSelected(int position) { updateIndicator(position); } @Override public void onPageScrollStateChanged(int state) { } }); addIndicator(); updateIndicator(0); } private void addIndicator() { for (int i = 0; i < fragmentList.size(); i++) { ImageView imageView = new ImageView(this); imageView.setImageResource(R.drawable.indicator_selector); LinearLayout.LayoutParams params = new LinearLayout.LayoutParams( LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT); params.setMargins(10, 0, 10, 0); indicator.addView(imageView, params); } } private void updateIndicator(int position) { for (int i = 0; i < indicator.getChildCount(); i++) { ImageView imageView = (ImageView) indicator.getChildAt(i); if (i == position) { imageView.setSelected(true); } else { imageView.setSelected(false); } } } } ``` 4. 创建一个Fragment,用于显示每一页的内容。可以在其中添加一个ImageView,用于显示图片。 ```java public class MyFragment extends Fragment { private int resId; public MyFragment() { } public MyFragment(int resId) { this.resId = resId; } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragment_my, container, false); ImageView imageView = (ImageView) view.findViewById(R.id.image_view); imageView.setImageResource(resId); return view; } } ``` 5. 添加动画效果(可选)。可以使用ViewPager的setCurrentItem()方法和Handler实现自动轮播效果,也可以使用ViewPager的setPageTransformer()方法添加页面切换动画效果。 ```java public class ZoomOutPageTransformer implements ViewPager.PageTransformer { private static final float MIN_SCALE = 0.85f; private static final float MIN_ALPHA = 0.5f; public void transformPage(View view, float position) { int pageWidth = view.getWidth(); int pageHeight = view.getHeight(); if (position < -1) { // [-Infinity,-1) // This page is way off-screen to the left. view.setAlpha(0f); } else if (position <= 1) { // [-1,1] // Modify the default slide transition to shrink the page as well float scaleFactor = Math.max(MIN_SCALE, 1 - Math.abs(position)); float vertMargin = pageHeight * (1 - scaleFactor) / 2; float horzMargin = pageWidth * (1 - scaleFactor) / 2; if (position < 0) { view.setTranslationX(horzMargin - vertMargin / 2); } else { view.setTranslationX(-horzMargin + vertMargin / 2); } // Scale the page down (between MIN_SCALE and 1) view.setScaleX(scaleFactor); view.setScaleY(scaleFactor); // Fade the page relative to its size. view.setAlpha(MIN_ALPHA + (scaleFactor - MIN_SCALE) / (1 - MIN_SCALE) * (1 - MIN_ALPHA)); } else { // (1,+Infinity] // This page is way off-screen to the right. view.setAlpha(0f); } } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值