【android】简易实现横向的ListView
众所周知,android里面的ListView是竖着的。
如果想要横向的话需要自定义一下ListView。
CSDN上面有个人描述了一下一个国外大神的自定义横向ListVIew 请点击 -->这里
自己也试了试这个HorizontalListView,发现bug还是不少 ,比如UI更新的时候排版总是不很正常,有时候item间距很大,有时候item间距很小。这让人很烦,所以就想着自己去实现以下简单的横向ListView
废话不多说:
布局 layout
<LinearLayout
android:id="@+id/imgContent"
android:layout_width="fill_parent"
android:layout_height="0dip"
android:layout_weight="10"
android:gravity="center_vertical"
android:orientation="vertical" > <HorizontalScrollView
android:layout_width="fill_parent"
android:layout_weight="1"
android:layout_height="0dip"
android:background="#eee" > <LinearLayout
android:id="@+id/thumbnailLinearLayout"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_gravity="center_vertical"
android:orientation="horizontal" >
</LinearLayout>
</HorizontalScrollView>
</LinearLayout>
对,你没有看错。布局文件就这么简单。还有个 horizontal_list_item 布局下面要用,但是里面就只有一个ImageView所以就没贴出来。
横向的ListView只需要一个 HorizontalScrollView和LinearLayout 就足够了 。
但是你会有疑问了,仅仅这样不能获取到LinearLayout里面的item啊,不能获取到item就不能给每个子View添加监听。别着急,向下看。
activity代码
//已经定义好的全局变量
listCount = 0;
for(String imgUrl : imgUrlList){ listCount++;
//加载布局
View view = mInflater.inflate(R.layout.horizontal_list_item,null);
//找到ImageView
ImageView thumImg = (ImageView)view.findViewById(R.id.img_list_item);
//设定图片宽高(80*80)
int w = getResources().getDimensionPixelOffset(R.dimen.thumnail_default_width);
int h = getResources().getDimensionPixelSize(R.dimen.thumnail_default_height); //图片绑定设置 ImageOptions imageOptions = new ImageOptions.Builder()
.setRadius(DensityUtil.dip2px(10))//ImageView圆角半径
.setSize(w,h)
.setCrop(true)
.setImageScaleType(ScaleType.FIT_CENTER)
.setLoadingDrawableId(R.drawable.img_loading)//加载中默认显示图片
.setFailureDrawableId(R.drawable.img_fail)
.build();
//异步加载图片
x.image().bind(thumImg, imgUrl, imageOptions); //添加到布局中
thumbnailLinearLayout.addView(view);
} thumbnailLinearLayout.setOnTouchListener(new OnTouchListener() { @Override
public boolean onTouch(View v, MotionEvent event) {
//获取到LinearLayout的宽度 注:在onCreat方法里面直接获取是0 所以要动态的获取
int width = thumbnailLinearLayout.getWidth();
//得到LinearLayout
int itemCount = thumbnailLinearLayout.getChildCount();
//计算出每一个child的平均宽度
float itemWidth = width/itemCount*1.0f;
//得到点击的X坐标
float touchX = event.getX(0);
//用这个式子算出点击坐标所在那个child上 (点击的坐标除以每个child的宽度 就可以得出所在child的索引) 需要 +1 吗?
int coverCount = (int) (touchX/itemWidth);
//有了索引就能干一些事情了
doSomething(coverCount); for(int i=0;i<itemCount;i++){
thumbnailLinearLayout.getChildAt(i).setBackgroundColor(Color.TRANSPARENT);
}
//添加背景颜色,方便区别 所点击的那个child
thumbnailLinearLayout.getChildAt(coverCount).setBackgroundColor(Color.rgb(120, 120, 120));
return false;
}
});
这段java代码写在activity的初始化控件里面。
重点在 thumbnailLinearLayout 设定setOnTouchListener 的方法里面 本来LinearLayout不能获取到自己的item 。但是可以用child来代替。获取到child和总长度以及touch的坐标(只需要X轴坐标)就能判定点下去的那个点相对于LinearLayout子View的索引了。
这只是一个简单的横向ListVIew ,能实现基本的 相册预览 功能。如果需要高级功能就自己自定义吧。
逻辑都在代码注释里面了。什么?看不懂? QQ462195349
【android】简易实现横向的ListView的更多相关文章
- Android简易记事本
此次做的Android简易记事本的存储方式使用了SQLite数据库,然后界面的实现比较简单,但是,具有增删改查的基本功能,这里可以看一下效果图,如下: 具体操作就是长按可以删除操作,点击可以进行修改, ...
- 【转】Android之自定义Adapter的ListView
http://www.cnblogs.com/topcoderliu/archive/2011/05/07/2039862.html 在开发中,我们经常使用到ListView这个控件.Android的 ...
- Android 自学之列表视图ListView和ListActivity
ListView是手机系统中使用非常广泛的一种组件,它以垂直列表的形式显示所有列表项. 创建ListView有两种方式: 直接使用ListView创建. 让Activity继承ListActivity ...
- android,在fragment中使用listview,不使用listfragment
public class LeftFragment extends Fragment{ private ListView listView; @Override public View onCreat ...
- android学习--视图列表(ListView和ListActivity)
说明: 视图列表(ListView和ListActivity)与AutoComplete.Spinner类似,它们都须要一个供显示的列表项,能够须要借助于内容Adapter提供显示列表项 创建List ...
- Android之自定义Adapter的ListView
ListView的创建,一般要具备两大元素: 1)数据集,即要映射的字符串.图片信息之类. 2)适配器,实现把要映射的字符串.图片信息映射成视图(如Textview.Image等组件),再添加到Lis ...
- Android简易实战教程--第五十一话《使用Handler实现增加、减少、暂停计数》
转载博客请注明出处:道龙的博客 之前,写过一篇使用异步任务AysncTask实现倒计时的小案例,喜欢的话可以参考博客:Android简易实战教程--第三十三话< AsyncTask异步倒计时&g ...
- Android简易实战教程--第五十话《动画扫描》
祝新年快乐!2017(一起)前行. 转载博客请注明出处:道龙的博客 本篇简答的小案例,使用动画知识,完成一个类似雷达扫描效果,并且加入自定义进度条.对于自定义进度条前面有很详细的解析和案例了,本篇就结 ...
- Android简易实战教程--第十六话《SharedPreferences保存用户名和密码》
之前在Android简易实战教程--第七话<在内存中存储用户名和密码> 那里是把用户名和密码保存到了内存中,这一篇把用户名和密码保存至SharedPreferences文件.为了引起误导, ...
随机推荐
- 1.3.2. App Icon 和 Launch Image(Core Data 应用程序实践指南)
App Icon: 选中 Assets.xcassets 选择 AppIcon ,并拖入图片(29.40.60) Launch Image: 创建 Launch Image 拖入图片(2x.R4)
- 前端程序员应该知道的 15 个 jQuery 小技巧
下面这些简单的小技巧能够帮助你玩转jQuery. 返回顶部按钮 预加载图像 检查图像是否加载 自动修复破坏的图像 悬停切换类 禁用输入字段 停止加载链接 切换淡入/幻灯片 简单的手风琴 让两个div高 ...
- 为什么delphi控件前面都有t
控件的类名都有一个T字, 它是Type的第一个字母. 比如按钮就是TButton. 但在Delphi的控件面板上的并不带T字, 比如就是Button. 如果你把它放在窗体上, 默认名字则成为Butto ...
- 浅谈Java工具类CommonUtils的使用
package com.xushouwei.cn; import java.util.HashMap; import java.util.Map; import org.junit.Test; imp ...
- js架构设计模式——你对MVC、MVP、MVVM 三种组合模式分别有什么样的理解?
你对MVC.MVP.MVVM 三种组合模式分别有什么样的理解? MVC(Model-View-Controller)MVP(Model-View-Presenter)MVVM(Model-View-V ...
- SVG的path的使用
SVG的path的使用: 参考:http://justcoding.iteye.com/blog/2226354 <%@ page language="java" conte ...
- Log4j与common-logging联系与区别
http://blog.csdn.net/courage89/article/details/29649801
- 为什么python适合写爬虫?(python到底有啥好的?!)
我用c#,java都写过爬虫.区别不大,原理就是利用好正则表达式.只不过是平台问题.后来了解到很多爬虫都是用python写的.因为目前对python并不熟,所以也不知道这是为什么.百度了下结果: 1) ...
- 【ci框架基础】之部署百度编辑器
在ci框架下加载编辑器,现在复习下内容.我的框架文件名称为ci 1.下载百度编辑器ueditor,http://ueditor.baidu.com/ 一般情况下下载ubuilder版即可,并将uedi ...
- 利用享元模式来解决DOM元素过多导致的网页解析慢、卡死的问题
我也不知道应该为本文的思路取一个什么比较恰当的标题,但是感觉符合享元模式的思路. 在一些网页应用中,有时会碰到一个超级巨大的列表,成千上万行,这时大部份浏览器解析起来就非常痛苦了(有可能直接卡死). ...