Android UI开源组件库BottomView ,第三方自定义UI控件

BottomView是一款适用于Android应用的多功能底部弹窗库,支持自定义布局、事件、背景透明度及动画效果。用户可以轻松地通过几个步骤将其集成到项目中,以增强用户体验。

这里分享一个Android的非常经典实用而且简单方便的第三方UI控件库:BottomView(小米的米UI也用到了这个)

实现功能:

可以在底部弹出的View里自定义布局;

可以自定义是否可以触摸外部消失;

可以自定义事件;

可以自定义外围背景是否透明;

可以自定义动画;

如果需要的话,可以强制为顶部View显示


BottomView.jar库文件下载地址:http://download.youkuaiyun.com/detail/jay100500/7547055

BottomView的Demo下载地址:http://download.youkuaiyun.com/detail/jay100500/7547049

用法:

1、下载BottomView.jar库文件,放到Android项目工程里的libs里

2、设置BottomView的Theme:

这2个Theme复制粘贴到你的项目的res/values/styles.xml里即可

<!--半透明背景Theme-->  
  <style name="BottomViewTheme_Defalut">  
       <item name="android:windowFrame">@null</item>  
       <item name="android:windowContentOverlay">@null</item>  
       <item name="android:windowIsFloating">true</item>  
       <item name="android:windowIsTranslucent">false</item>  
       <item name="android:windowNoTitle">true</item>  
       <item name="android:windowBackground">@color/white</item>  
       <item name="android:backgroundDimEnabled">true</item>  
       <item name="android:windowFullscreen">true</item>  
   </style>  
lt;!--透明背景Theme-->  
   <style name="BottomViewTheme_Transparent">  
       <item name="android:windowFrame">@null</item>  
       <item name="android:windowIsFloating">true</item>  
       <!-- Transparent -->  
       <item name="android:windowIsTranslucent">false</item>  
       <item name="android:windowContentOverlay">@null</item>  
       <item name="android:windowNoTitle">true</item>  
       <item name="android:windowBackground">@color/white</item>  
       <item name="android:backgroundDimEnabled">false</item>  
   </style>  

另外如果提示

    <item name="android:windowBackground">@color/white</item> 

这里的white找不到的话,说明你项目res/values/color.xml没有新建或者没有white颜色这个值,只需在res/values/color.xml里添加

    <color name="white">#ffffff</color>  
这个白色值即可。

另外View的动画Theme可选,建议也复制进去,效果好一些,代码如下:

res/anim/bottomview_anim_enter.xml


[html]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. <?xml version="1.0" encoding="utf-8"?>    
  2. <set xmlns:android="http://schemas.android.com/apk/res/android" >    
  3.     
  4.     <translate    
  5.         android:duration="500"    
  6.         android:fromYDelta="100%p" />    
  7.     
  8. </set>  

[html]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. res/anim/bottomview_anim_exit.xml  
[html]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. <?xml version="1.0" encoding="utf-8"?>    
  2. <set xmlns:android="http://schemas.android.com/apk/res/android" >    
  3.     
  4.     <translate    
  5.         android:duration="500"    
  6.         android:toYDelta="100%p" />    
  7.     
  8. </set>   
整体为:


2、部分核心使用代码:

[html]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. BottomView bottomView = new BottomView(this,    
  2.                     R.style.BottomViewTheme_Defalut, R.layout.bottom_view);    
  3.             bottomView.setAnimation(R.style.BottomToTopAnim);//设置动画,可选    
  4.             bottomView.showBottomView(false);  

如果想获取这个View的话,调用.getView()方法即可。

效果图之一:(可随意发挥)



1、Android显示GIF动画 GifView GifView 是一个为了解决android中现在没有直接显示gif的view,只能通过mediaplay来显示这个问题的项目,其用法和 ImageView一样,支持gif图片 使用方法:1-把GifView.jar加入你的项目。2-在xml中配置GifView的基本属性,GifView继承自View类,和Button、ImageView一样是一个UI控件。 如: 3-在代码中配置常用属性: // 从xml中得到GifView的句柄 gf1 = (GifView) findViewById(R.id.gif1); // 设置Gif图片源 gf1.setGifImage(R.drawable.gif1); // 添加监听器 gf1.setOnClickListener(this); // 设置显示的大小,拉伸或者压缩 gf1.setShowDimension(300, 300); // 设置加载方式:先加载后显示、边加载边显示、只显示第一帧再显示 gf1.setGifImageType(GifImageType.COVER); GifView的Jar包共有四个类: GifAction.java 观察者类,监视GIF是否加载成功 GifFrame.java 里面三个成员:当前图片、延时、下张Frame的链接。 GifDecoder.java 解码线程类 GifView.java 主类,包括常用方法,如GifView构造方法、设置图片源、延迟、绘制等。 2、Calendar.v0.5.0 是 Android 平台的一个日历显示组件。 3、CWAC EndlessAdapter 是 Android 上一个可以无限往下滑进行列表数据加载的控件。 4、Android Horizontal ListView 是 Android 上一个水平滑动的 ListView 组件。 5、Android ViewBadger 视图布局。 6、滑动刷新的ListView Android PullToRefresh 为 Android 应用提供一个向下滑动即刷新列表的功能,就两个目标文件。 7、pakerfeldt-android-viewflow 是 Android 平台上一个视图切换的效果库。ViewFlow 相当于 Android UI 部件提供水平滚动的 ViewGroup,使用 Adapter 进行条目绑定。 8、Android 导航菜单 RibbonMenu 是 Android 上的一个导航菜单组件。就三个目标文件,菜单项直接在 XML 中定义,可添加文本和图标。 9、AndroidUI工具包 android-ui-utils 是一个工具包用来帮助设计和开发 Android 用户界面,包含三个单独的工具:Android Asset Studio用户界面原型模具,Android 设计预览,时常需要重复确认程序版面设计状况的 Android App 开发者,应该会爱上这个轻量级的 Java 程序:Andorid Design Preview 工具,通过 USB 连接之后,只要简单的在计算机中选取您想要显示的程序版面范围,就可将镜像结果直接显示于手机装置之上。 10、Androidui开发类库 GreenDroid 是一个Androidui开发类库,能够使你的Android开发更加简便和快捷。 11、Android滑动式菜单 SlidingMenu 是 Android 上实现类似 Facebook 和 Path 2.0 滑动式菜单的组件。 12、AsyncImageView 是 Android 上的一个异步从网络上获取图片并进行浏览的开源组件,可自动在本地进行缓存。该项目是 GreenDroid 的一部分。 13、仿Path按钮动画效果 PathButton 仿照Path应用首页左下角的Button动画效果写了个简单的Demo,由于数学不好,坐标总是和理想有出入,只是大致实现了动画效果,若果有人能把坐标算对,那么修改我的demo就能做成类似Path的那种动画效果!希望大家出点力帮着优化一下,并分享出来! 14、Android Intent开发包 OpenIntents Ope
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值