初学Android之viewPager+imageLoader+图片圆角(类似qq头像)+xListView+DrawLayout
有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相关推荐
- java图片裁剪类似qq头像_Android实现类似换QQ头像功能(图片裁剪)
现在几乎所有的App都有用户登录模块,需要设置用户头像,而关于用户头像部分无疑也是比较头疼的,目前大部分应用的头像部分会有两种方式:一种是利用系统的裁剪功能去获取用户头像,一种就是获取到图片或者照片的 ...
- [Android]使用ViewPager实现图片滑动展示
在淘宝等电商的APP首页经常能看到大幅的广告位,通常有多幅经常更新的图片用于展示促销信息,如下图所示: 通常会自动滚动,也可以根据手势滑动.我没有研究过人家的APP是通过什么实现的,可能有第三方已经封 ...
- Android使用ViewPager实现图片轮播和手势滑动
ViewPager常用来实现图片的轮播,比如淘宝首页,会把一些促销的商品的图片和描述信息来回的播放,这就是典型的使用ViewPager实现的. ViewPager属于布局管理器,允许用户通过页面翻转查 ...
- Android利用ViewPager实现图片浏览,解决内存问题
在Android开发中,我们经常遇到利用Viewpager实现图片浏览的需求,这个很好实现,也没什么技术难点,但是最近我在实现这个功能的时候,遇到了一些问题,当图片数量稍微多点时,一直滑动浏览,会导致 ...
- Android 自定义RecycleView实现多级树(类似qq分组列表)
由于工作需要开发一个类似qq分组列表功能,所以就自定义RecycleView来实现功能 效果图: 自定义View: import java.util.ArrayList; import java.ut ...
- Android 高仿ImageLoader图片加载
一.首先,废话不多说,先上图片 二.实现思路 1.缓存在本地和内存中,每次加载都从本地中读取,如果本地没有则从网络下载,并保存到本地或者内存 2.内存缓存使用软引用和LruCache算法 3.本地缓存 ...
- Android之ViewPager实现图片无限循环轮播
很久没有写博客了,之前花时间写了一个Viewpager实现的无限图片轮播,个人感觉还是很好用的QAQ,源码和思路都还算清晰 实现的效果图如下: 这里要补充一下,在这个项目中我把图片轮播写进了一个Vie ...
- Android使用viewpager实现图片轮播效果
自定义View实现图片轮播,实现了图片自动轮播,手动滑动,轮播标题,以及点击事件. 里面有很多注释 一.文件布局 二.代码 ImageBannerViewGroup类 /*** Created by ...
- Android 加载长图片(类似微博长图)
巨图片加载,android BitmapRegionDecoder . 1.BitmapRegionDecoder.newInstance(); 2.bitmap = mDecoder.decodeR ...
最新文章
- Linux那些事儿之我是Sysfs(7)dentry与inode
- python计算tfidf sklearn计算
- why context node binding does not work in pop up window case
- springboot配置跨mapper.xml的全局变量
- Python RSA
- java 内部类_java的内部类和静态内部类(嵌套类)
- [agc011e]increasing numbers
- 项目管理沙龙第十一次聚会纪要--当敏捷没有共识的时候
- mqtt之C++编译
- Native Instruments Battery 4 for mac - 尖端鼓采样器
- 设为首页 和 收藏本页
- Excel数据分析--客户对象分析
- python海词查单词
- 机器学习 | MATLAB实现GLM广义线性模型参数设定
- linux ape,Linux下APE歌曲的制作
- 今年的金德值得期待的人物_原水_新浪博客
- 2021年N1叉车司机考试总结及N1叉车司机操作证考试
- springboot框架
- Matplotlib下plt常用指令总结
- Informatica bulk和normal模式
热门文章
- python 定义一个无限制的二维数组方法
- i9 10900k配什么主板 显卡好
- js获取radio选中值
- 修改 下载仓库为淘宝镜像 npm config set registry https://registry.npmjs.org/, 如果要发布自己的镜像需要修改回来 npm
- 一个简单的用表单标签做的html学生入校注册页面
- 心理学与生活-情绪与情感
- 股市是合法赌场 黄金是最大泡沫
- Linux 的 微微 微微 微微 高级 教程 | web nginx 1
- AdaTree决策树算法(C5)C#源码
- 计算机游戏攻略32关,保卫萝卜3单机版集市第32关攻略 有很多隐藏炮塔