有adapter、application、bean、view这几个包 接下来就按照顺序去写一下

首先是adapter

public class MyPagerAdapter extends PagerAdapter{
    Context context;
    List<String> alist;
    public MyPagerAdapter(Context context, List<String> alist) {
        this.context=context;
        this.alist=alist;
    }

@Override
    public int getCount() {
        return Integer.MAX_VALUE;
    }

@Override
    public boolean isViewFromObject(View view, Object object) {
        return view==object;
    }

@Override
    public Object instantiateItem(ViewGroup container, int position) {
        ImageView imageView = new ImageView(context);
        ImageLoader.getInstance().displayImage(alist.get(position%=alist.size()),imageView);
        container.addView(imageView);
        return imageView;

}

@Override
    public void destroyItem(ViewGroup container, int position, Object object) {
        container.removeView((View) object);
    }
}

-------------------------------------------------------

public class MyxlvAdapter extends BaseAdapter{
    private int LEFT_IMAGE=0;
    private int RIGHT_IMAGE=1;
    Context context;
    List<DataDataBean.DataBean> list;
    public MyxlvAdapter(Context context, List<DataDataBean.DataBean> list) {
        this.context=context;
        this.list=list;
    }

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

@Override
    public Object getItem(int i) {
        return list.get(i);
    }

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

@Override
    public int getViewTypeCount() {
        return 2;
    }

@Override
    public int getItemViewType(int position) {
        if(position%2==0)
        {
            return LEFT_IMAGE;
        }
        else{
            return RIGHT_IMAGE;
        }
    }

@Override
    public View getView(int i, View view, ViewGroup viewGroup) {
        if(getItemViewType(i)==LEFT_IMAGE)
        {
            ViewHolder_01 holder=null;
            if(view==null)
            {
                view=View.inflate(context, R.layout.left_layout,null);
                holder=new ViewHolder_01();
                holder.tv=(TextView) view.findViewById(R.id.left_tv);
                holder.iv= (ImageView) view.findViewById(R.id.left_iv);
                view.setTag(holder);
            }
            else{
                holder= (ViewHolder_01) view.getTag();
            }
            holder.tv.setText(list.get(i).getTitle());
            ImageLoader.getInstance().displayImage(list.get(i).getImg(),holder.iv, ImageLoaderUtil.getCircleOption());

}
        else{
            ViewHolder holder=null;
            if(view==null)
            {
                view=View.inflate(context, R.layout.right_layout,null);
                holder=new ViewHolder();
                holder.tv=(TextView) view.findViewById(R.id.right_tv);
                view.setTag(holder);
            }
            else{
                holder= (ViewHolder) view.getTag();
            }
            holder.tv.setText(list.get(i).getTitle());
            //ImageLoader.getInstance().displayImage(list.get(i).getImg(),holder.iv, ImageLoaderUtil.getDefaultOption());
        }
        return view;
    }

private class ViewHolder_01{
        TextView tv;
        ImageView iv;
    }

private class ViewHolder{
        TextView tv;
        ImageView iv;
    }

}

--------------------------------------------------

import android.content.Context;
import android.graphics.Bitmap;
import android.os.Environment;
import com.bawei.administrator.lianxi_1013ev.R;
import com.nostra13.universalimageloader.cache.disc.impl.UnlimitedDiskCache;
import com.nostra13.universalimageloader.cache.memory.impl.LruMemoryCache;
import com.nostra13.universalimageloader.core.DisplayImageOptions;
import com.nostra13.universalimageloader.core.ImageLoader;
import com.nostra13.universalimageloader.core.ImageLoaderConfiguration;
import com.nostra13.universalimageloader.core.assist.ImageScaleType;
import com.nostra13.universalimageloader.core.assist.QueueProcessingType;
import com.nostra13.universalimageloader.core.display.CircleBitmapDisplayer;
import com.nostra13.universalimageloader.core.display.RoundedBitmapDisplayer;
import com.nostra13.universalimageloader.core.display.SimpleBitmapDisplayer;
import com.nostra13.universalimageloader.utils.StorageUtils;

import java.io.File;

/**
 * @author Dash
 * @date 2017/10/10
 * @description:
 */
public class ImageLoaderUtil {

/**
     * 对imageLoader进行配置的方法
     * @param context 上下文
     */
    public static void init(Context context) {

File cacheDir = StorageUtils.getCacheDirectory(context);  //指定默认的硬盘(sd卡)的缓存文件夹路径

/**
         * 可以自己创建一个sd下面的文件夹作为硬盘缓存的路径
         */
        File file = new File(Environment.getExternalStorageDirectory(),"image");
        if (! file.exists()){
            file.mkdirs();
        }

//1.创建一个ImageLoaderConfiguration,,,图片加载器的配置对象
        ImageLoaderConfiguration config = new ImageLoaderConfiguration.Builder(context)

.threadPoolSize(3) // default  线程池内加载的数量
                .threadPriority(Thread.NORM_PRIORITY - 2) // default 设置当前线程的优先级
                .tasksProcessingOrder(QueueProcessingType.FIFO) // default
                .denyCacheImageMultipleSizesInMemory()

//1 TB = 1024GB 1G=1024MB 1M = 1024KB 1KB = 1024BYTE
                //LruMemoryCache,,lru最近最少使用算法...内部维护的是LinkedHashMap,,当一张图片最近很少使用的时候会从mao集合里面移除
                .memoryCache(new LruMemoryCache(2 * 1024 * 1024)) //指定内存缓存的大小,,2M,,可以通过自己的内存缓存实现
                .memoryCacheSize(2 * 1024 * 1024)  // 内存缓存的最大值
                .memoryCacheSizePercentage(13) // default

//指定硬盘/磁盘缓存的路径
                .diskCache(new UnlimitedDiskCache(cacheDir)) // default 可以自定义缓存路径
                .diskCacheSize(50 * 1024 * 1024) // 50 Mb sd卡(本地)缓存的最大值
                .diskCacheFileCount(100)  // 可以缓存的文件数量

.defaultDisplayImageOptions(DisplayImageOptions.createSimple()) // default
                .writeDebugLogs() // 打印debug log
                .build(); //开始构建

//2.对上面配置对象的初始化
        ImageLoader.getInstance().init(config);

}

/**
     * 默认的展示图片的选项
     *
     * @return
     */
    public static DisplayImageOptions getDefaultOption() {
        DisplayImageOptions options = new DisplayImageOptions.Builder()
                .showImageOnLoading(R.mipmap.ic_launcher) // 设置图片下载期间显示的图片
                .showImageForEmptyUri(R.mipmap.ic_launcher) // 设置图片Uri为空或是错误的时候显示的图片
                .showImageOnFail(R.mipmap.ic_launcher) // 设置图片加载或解码过程中发生错误显示的图片

.resetViewBeforeLoading(true)  // default 设置图片在加载前是否重置、复位

.cacheInMemory(true) // default  设置下载的图片是否缓存在内存中
                .cacheOnDisk(true) // default  设置下载的图片是否缓存在SD卡中

.considerExifParams(true) // default

.imageScaleType(ImageScaleType.EXACTLY_STRETCHED) // default 设置图片以如何的编码方式显示
                .bitmapConfig(Bitmap.Config.RGB_565) // default 设置图片的解码类型

.displayer(new SimpleBitmapDisplayer()) // default  还可以设置圆角图片new RoundedBitmapDisplayer(20)

.build();

return options;
    }

/**
     * 展示圆角的选项
     * @return
     */
    public static DisplayImageOptions getRoundOption() {
        DisplayImageOptions options = new DisplayImageOptions.Builder()
                .showImageOnLoading(R.mipmap.ic_launcher) // 设置图片下载期间显示的图片
                .showImageForEmptyUri(R.mipmap.ic_launcher) // 设置图片Uri为空或是错误的时候显示的图片
                .showImageOnFail(R.mipmap.ic_launcher) // 设置图片加载或解码过程中发生错误显示的图片

.resetViewBeforeLoading(true)  // default 设置图片在加载前是否重置、复位

.cacheInMemory(true) // default  设置下载的图片是否缓存在内存中
                .cacheOnDisk(true) // default  设置下载的图片是否缓存在SD卡中

.considerExifParams(true) // default

.imageScaleType(ImageScaleType.EXACTLY_STRETCHED) // default 设置图片以如何的编码方式显示
                .bitmapConfig(Bitmap.Config.RGB_565) // default 设置图片的解码类型

.displayer(new RoundedBitmapDisplayer(20)) // default  还可以设置圆角图片new RoundedBitmapDisplayer(20)

.build();

return options;
    }

/**
     * 展示圆形的选项
     * @return
     */
    public static DisplayImageOptions getCircleOption() {
        DisplayImageOptions options = new DisplayImageOptions.Builder()
                .showImageOnLoading(R.mipmap.ic_launcher) // 设置图片下载期间显示的图片
                .showImageForEmptyUri(R.mipmap.ic_launcher) // 设置图片Uri为空或是错误的时候显示的图片
                .showImageOnFail(R.mipmap.ic_launcher) // 设置图片加载或解码过程中发生错误显示的图片

.resetViewBeforeLoading(true)  // default 设置图片在加载前是否重置、复位

.cacheInMemory(true) // default  设置下载的图片是否缓存在内存中
                .cacheOnDisk(true) // default  设置下载的图片是否缓存在SD卡中

.considerExifParams(true) // default

.imageScaleType(ImageScaleType.EXACTLY_STRETCHED) // default 设置图片以如何的编码方式显示
                .bitmapConfig(Bitmap.Config.RGB_565) // default 设置图片的解码类型

.displayer(new CircleBitmapDisplayer()) // default  还可以设置圆角图片new RoundedBitmapDisplayer(20)

.build();

return options;
    }
}

-----------------------------------------------------------------------------------------

就剩主方法了

public class MainActivity extends AppCompatActivity implements XListView.IXListViewListener {

private XListView xlv;
    private ListView lv;
    private ViewPager vp;
    private List<String> title;
    private List<DataDataBean.DataBean> list=new ArrayList<>();
    private MyxlvAdapter myadapter;
    private List<String> alist=new ArrayList<>();
    private ImageView iv;
    private DrawerLayout dl;
    private RelativeLayout relaa;
    int NUM=1;

@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        xlv = (XListView) findViewById(R.id.xlv);
        lv = (ListView) findViewById(R.id.lview);
        //vp = (ViewPager) findViewById(R.id.vp);
        iv = (ImageView) findViewById(R.id.iv);
        dl = (DrawerLayout) findViewById(R.id.draw);
        relaa = (RelativeLayout) findViewById(R.id.relaa);
        xlv.setPullRefreshEnable(true);
        xlv.setPullLoadEnable(true);
        xlv.setXListViewListener(this);

iv.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                dl.closeDrawer(relaa);
            }
        });

title = new ArrayList<>();
        title.add("头条");
        title.add("社会");
        title.add("国内");
        title.add("军事");
        title.add("财经");

ArrayAdapter adapter = new ArrayAdapter(MainActivity.this, android.R.layout.simple_list_item_1, android.R.id.text1, title);
        lv.setAdapter(adapter);

getDataFromNet();

}

private void getDataFromNet() {
        AsyncTask<Void, Void, String> asyncTask = new AsyncTask<Void, Void, String>() {
            @Override
            protected String doInBackground(Void... voids) {
                try {
                    String path = "http://www.yulin520.com/a2a/impressApi/news/mergeList?pageSize=10&page="+NUM;
                    URL url = new URL(path);
                    HttpURLConnection connection = (HttpURLConnection) url.openConnection();
                    connection.setConnectTimeout(5000);
                    connection.setReadTimeout(5000);
                    connection.setRequestMethod("GET");
                    int responseCode = connection.getResponseCode();
                    if (responseCode == 200) {
                        InputStream inputStream = connection.getInputStream();
                        String json = streamToString(inputStream, "utf-8");

return json;
                    }

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

return null;
            }

@Override
            protected void onPostExecute(String s) {
                Log.i("json" , s);

Gson gson = new Gson();
                DataDataBean dataDataBean = gson.fromJson(s, DataDataBean.class);
                list.addAll(dataDataBean.getData());
                setAdapter();
                //停止加载
                xlv.stopLoadMore();

for(int i=0;i<dataDataBean.getData().size();i++)
                {
                    alist.add(dataDataBean.getData().get(i).getImg());
                }

//MyPagerAdapter myPagerAdapter = new MyPagerAdapter(MainActivity.this,alist);
               // vp.setAdapter(myPagerAdapter);

//初始化小圆点
            }

};
        asyncTask.execute();
    }

private void setAdapter() {
        if (myadapter == null){

MyxlvAdapter myadapter=new MyxlvAdapter(MainActivity.this, list);
            xlv.setAdapter(myadapter);
        }else {
            myadapter.notifyDataSetChanged();
        }
    }

private String streamToString(InputStream inputStream, String s) {
        try {
            InputStreamReader inputStreamReader = new InputStreamReader(inputStream,s);
            BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
            String string=null;
            StringBuilder stringBuilder = new StringBuilder();
            while((string=bufferedReader.readLine())!=null)
            {
                stringBuilder.append(string);
            }

bufferedReader.close();

return stringBuilder.toString();

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

@Override
    public void onRefresh() {
        AsyncTask<Void, Void, String> asyncTask = new AsyncTask<Void, Void, String>() {
            @Override
            protected String doInBackground(Void... voids) {
                try {
                    String path = "http://www.yulin520.com/a2a/impressApi/news/mergeList?pageSize=10&page=1";
                    URL url = new URL(path);
                    HttpURLConnection connection = (HttpURLConnection) url.openConnection();
                    connection.setConnectTimeout(5000);
                    connection.setReadTimeout(5000);
                    connection.setRequestMethod("GET");
                    int responseCode = connection.getResponseCode();
                    if (responseCode == 200) {
                        InputStream inputStream = connection.getInputStream();
                        String json = streamToString(inputStream, "utf-8");
                        return json;
                    }

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

return null;
            }

@Override
            protected void onPostExecute(String s) {
                Gson gson = new Gson();
                DataDataBean dataDataBean = gson.fromJson(s, DataDataBean.class);
                list.addAll(dataDataBean.getData());
                setAdapter();

xlv.stopRefresh();

Date date = new Date(System.currentTimeMillis());
                SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm");
                xlv.setRefreshTime(simpleDateFormat.format(date));
            }

};
        asyncTask.execute();
    }

@Override
    public void onLoadMore() {
        NUM++;

getDataFromNet();
    }
}

下面是布局

主布局

<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayout
    android:id="@+id/draw"
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

<RelativeLayout
        android:id="@+id/rela"
        android:layout_width="match_parent"
        android:layout_height="match_parent">

<!--<android.support.v4.view.ViewPager-->
            <!--android:id="@+id/vp"-->
            <!--android:layout_width="match_parent"-->
            <!--android:layout_height="200dp"></android.support.v4.view.ViewPager>-->

<com.bawei.administrator.lianxi_1013ev.view.XListView
            android:id="@+id/xlv"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_below="@+id/vp"></com.bawei.administrator.lianxi_1013ev.view.XListView>

</RelativeLayout>
    
    <RelativeLayout
        android:id="@+id/relaa"
        android:layout_width="200dp"
        android:layout_height="match_parent"
        android:layout_gravity="left"
        android:background="#fff">
        
        <ImageView
            android:id="@+id/iv"
            android:layout_width="70dp"
            android:layout_height="70dp"
            android:src="@mipmap/ic_launcher"/>
        
        <ListView
            android:layout_below="@+id/iv"
            android:id="@+id/lview"
            android:layout_width="match_parent"
            android:layout_height="200dp"></ListView>
        
    </RelativeLayout>

</android.support.v4.widget.DrawerLayout>

***************************

左图右文字布局

<?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">

<ImageView
        android:id="@+id/left_iv"
        android:layout_width="100dp"
        android:layout_height="100dp" />
    <TextView
        android:id="@+id/left_tv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />

</LinearLayout>

只有文字的布局

<?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">

<TextView
        android:id="@+id/right_tv"
        android:gravity="right"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />

</LinearLayout>

初学Android之viewPager+imageLoader+图片圆角(类似qq头像)+xListView+DrawLayout相关推荐

  1. java图片裁剪类似qq头像_Android实现类似换QQ头像功能(图片裁剪)

    现在几乎所有的App都有用户登录模块,需要设置用户头像,而关于用户头像部分无疑也是比较头疼的,目前大部分应用的头像部分会有两种方式:一种是利用系统的裁剪功能去获取用户头像,一种就是获取到图片或者照片的 ...

  2. [Android]使用ViewPager实现图片滑动展示

    在淘宝等电商的APP首页经常能看到大幅的广告位,通常有多幅经常更新的图片用于展示促销信息,如下图所示: 通常会自动滚动,也可以根据手势滑动.我没有研究过人家的APP是通过什么实现的,可能有第三方已经封 ...

  3. Android使用ViewPager实现图片轮播和手势滑动

    ViewPager常用来实现图片的轮播,比如淘宝首页,会把一些促销的商品的图片和描述信息来回的播放,这就是典型的使用ViewPager实现的. ViewPager属于布局管理器,允许用户通过页面翻转查 ...

  4. Android利用ViewPager实现图片浏览,解决内存问题

    在Android开发中,我们经常遇到利用Viewpager实现图片浏览的需求,这个很好实现,也没什么技术难点,但是最近我在实现这个功能的时候,遇到了一些问题,当图片数量稍微多点时,一直滑动浏览,会导致 ...

  5. Android 自定义RecycleView实现多级树(类似qq分组列表)

    由于工作需要开发一个类似qq分组列表功能,所以就自定义RecycleView来实现功能 效果图: 自定义View: import java.util.ArrayList; import java.ut ...

  6. Android 高仿ImageLoader图片加载

    一.首先,废话不多说,先上图片 二.实现思路 1.缓存在本地和内存中,每次加载都从本地中读取,如果本地没有则从网络下载,并保存到本地或者内存 2.内存缓存使用软引用和LruCache算法 3.本地缓存 ...

  7. Android之ViewPager实现图片无限循环轮播

    很久没有写博客了,之前花时间写了一个Viewpager实现的无限图片轮播,个人感觉还是很好用的QAQ,源码和思路都还算清晰 实现的效果图如下: 这里要补充一下,在这个项目中我把图片轮播写进了一个Vie ...

  8. Android使用viewpager实现图片轮播效果

    自定义View实现图片轮播,实现了图片自动轮播,手动滑动,轮播标题,以及点击事件. 里面有很多注释 一.文件布局 二.代码 ImageBannerViewGroup类 /*** Created by ...

  9. Android 加载长图片(类似微博长图)

    巨图片加载,android BitmapRegionDecoder . 1.BitmapRegionDecoder.newInstance(); 2.bitmap = mDecoder.decodeR ...

最新文章

  1. Linux那些事儿之我是Sysfs(7)dentry与inode
  2. python计算tfidf sklearn计算
  3. why context node binding does not work in pop up window case
  4. springboot配置跨mapper.xml的全局变量
  5. Python RSA
  6. java 内部类_java的内部类和静态内部类(嵌套类)
  7. [agc011e]increasing numbers
  8. 项目管理沙龙第十一次聚会纪要--当敏捷没有共识的时候
  9. mqtt之C++编译
  10. Native Instruments Battery 4 for mac - 尖端鼓采样器
  11. 设为首页 和 收藏本页
  12. Excel数据分析--客户对象分析
  13. python海词查单词
  14. 机器学习 | MATLAB实现GLM广义线性模型参数设定
  15. linux ape,Linux下APE歌曲的制作
  16. 今年的金德值得期待的人物_原水_新浪博客
  17. 2021年N1叉车司机考试总结及N1叉车司机操作证考试
  18. springboot框架
  19. Matplotlib下plt常用指令总结
  20. Informatica bulk和normal模式

热门文章

  1. python 定义一个无限制的二维数组方法
  2. i9 10900k配什么主板 显卡好
  3. js获取radio选中值
  4. 修改 下载仓库为淘宝镜像 npm config set registry https://registry.npmjs.org/, 如果要发布自己的镜像需要修改回来 npm
  5. 一个简单的用表单标签做的html学生入校注册页面
  6. 心理学与生活-情绪与情感
  7. 股市是合法赌场 黄金是最大泡沫
  8. Linux 的 微微 微微 微微 高级 教程 | web nginx 1
  9. AdaTree决策树算法(C5)C#源码
  10. 计算机游戏攻略32关,保卫萝卜3单机版集市第32关攻略 有很多隐藏炮塔