返回顶部
首页 > 资讯 > 移动开发 >Android开发之实现GridView支付宝九宫格
  • 849
分享到

Android开发之实现GridView支付宝九宫格

android开发gridviewAndroid 2022-06-06 09:06:26 849人浏览 八月长安
摘要

先给大家展示下关于仿支付宝钱包首页中带有分割线的gridview,俗称九宫格 的效果图,怎么样是不是和你想象的一样啊。在你的预料之中就继续访问以下代码内容吧。 我们都知道Li

先给大家展示下关于仿支付宝钱包首页中带有分割线的gridview,俗称九宫格 的效果图,怎么样是不是和你想象的一样啊。在你的预料之中就继续访问以下代码内容吧。

我们都知道ListView设置分割线是非常容易的,设置ListView的分割线颜色和宽度,只需要在布局中定义Android:divider和android:dividerHeight属性即可。而GridView并没有这样的属性和方法,那我们改如何来做呢?

编程网小编在做这个效果之前,也参考了其他的一些方案,比如说定义一个自定义的GridView,然后在dispatchDraw()方法中在每个item的四周加上一条分割线,这是需要靠算法来实现的,最后这种方法实现的效果并不理想,会出现有些item中没有加上分割线,很难达到我们想要的这种效果。

其实实现这种效果并不难,原理就是让每个item都设置成带有分割线的背景,这样就很容易实现了。

首先我们来写布局:


<LinearLayout xmlns:android="Http://schemas.android.com/apk/res/android" 
 android:layout_width="match_parent" 
 android:layout_height="match_parent" 
 android:orientation="vertical" > 
  <ScrollView 
  android:layout_width="fill_parent" 
  android:layout_height="wrap_content" 
  android:fillViewport="true" 
  android:scrollbars="none" > 
  <com.finddreams.alipay.MyGridView 
   android:id="@+id/gridview" 
   android:layout_width="fill_parent" 
   android:layout_height="wrap_content" 
   android:horizontalSpacing="0.0dip" 
   android:listSelector="@null" 
   android:numColumns="3" 
   android:scrollbars="none" 
   android:stretchMode="columnWidth" 
   android:verticalSpacing="0.0dip" /> 
 </ScrollView> 
</LinearLayout> 

        因为有时候我们的Gridview中的item可能比较多,为了放得下,一般都会用一个ScrollView来嵌套起来。这时就会出现一个常见的问题,我们在开发中经常会碰到,就是当ListView或者GridView被嵌套在ScrollView中时,发现只会显示第一行的数据,后面的数据就不会显示了。至于产生这个问题的原因,可能是因为Gridview和ListView都是可以根据子item的宽高来显示大小的,但是一旦嵌套到ScrollView中就可以上下滑动,于是系统就不能确定到底该画多大,所以才会产生这样的问题。

      这个问题的解决方法在网上很多,一般百度一下就能查到,下面是GridView的解决方法:


public class MyGridView extends GridView { 
 public MyGridView(Context context, AttributeSet attrs) { 
  super(context, attrs); 
 } 
 public MyGridView(Context context) { 
  super(context); 
 } 
 public MyGridView(Context context, AttributeSet attrs, int defStyle) { 
  super(context, attrs, defStyle); 
 } 
 @Override 
 public void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { 
  int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2, 
    MeasureSpec.AT_MOST); 
  super.onMeasure(widthMeasureSpec, expandSpec); 
 } 
} 

      接下来,我们就定义一个带分割线的选择器,具体代码是:


<?xml version="1.0" encoding="utf-8"?> 
<selector xmlns:android="http://schemas.android.com/apk/res/android"> 
 <item android:state_pressed="true"><shape android:shape="rectangle"> 
   <stroke android:width="1.0px" android:color="@color/line" /> 
   <gradient android:angle="270.0" android:endColor="#ffe8ecef" android:startColor="#ffe8ecef" /> 
  </shape></item> 
 <item android:state_focused="true"><shape android:shape="rectangle"> 
   <gradient android:angle="270.0" android:endColor="#ffe8ecef" android:startColor="#ffe8ecef" /> 
   <stroke android:width="1.0px" android:color="@color/line" /> 
  </shape></item> 
 <item><shape android:shape="rectangle"> 
   <gradient android:angle="270.0" android:endColor="#ffffffff" android:startColor="#ffffffff" /> 
   <stroke android:width="1.0px" android:color="@color/line" /> 
  </shape></item> 
</selector> 

定义一个selector,在里面设置一个形状为矩形rectangle,设置这个矩形的stroke描边属性的颜色为分割线的颜色,然后在不同的state的item中设置不同的gradient渐变属性,从而实现在单个item在被点击选中时的效果。

接着就是给我们GridView的item布局中加上背景了:


<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 android:layout_width="fill_parent" 
 android:layout_height="fill_parent" 
 android:layout_margin="0.0dip" 
 android:background="@color/griditems_bg" > 
 <RelativeLayout 
  android:layout_width="fill_parent" 
  android:layout_height="fill_parent" 
  android:layout_centerInParent="true" 
  android:background="@drawable/bg_gv" 
  android:padding="12.0dip" > 
  <ImageView 
   android:id="@+id/iv_item" 
   android:layout_width="58.0dip" 
   android:layout_height="58.0dip" 
   android:layout_centerHorizontal="true" 
   android:contentDescription="@string/app_name" /> 
  <TextView 
   android:id="@+id/tv_item" 
   android:layout_width="wrap_content" 
   android:layout_height="wrap_content" 
   android:layout_below="@id/iv_item" 
   android:layout_centerHorizontal="true" 
   android:layout_marginTop="5.0dip" 
   android:maxLines="1" 
   android:textColor="@color/commo_text_color" 
   android:textSize="14.0sp" /> 
 </RelativeLayout> 
</RelativeLayout> 

      到这里,就要开始写代码了,定义一个Adapter,把数据填充到GridView中,这一步我想大家都应该都很清楚,这里就不多讲了,不懂的话,可以参考下面的项目代码。

您可能感兴趣的文章:Android 九宫格的实现方法android 九宫格滑动解开机实例源码学习Android实现九宫格(GridView中各项平分空间)的方法Android打造流畅九宫格抽奖活动效果轻松实现Android自定义九宫格图案解锁Android编程之九宫格实现方法实例分析Android实现九宫格解锁的方法Android学习教程之九宫格图片展示(13)Android布局案例之人人android九宫格android实现九宫格程序


--结束END--

本文标题: Android开发之实现GridView支付宝九宫格

本文链接: https://lsjlt.com/news/26290.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Android开发之实现GridView支付宝九宫格
    先给大家展示下关于仿支付宝钱包首页中带有分割线的gridview,俗称九宫格 的效果图,怎么样是不是和你想象的一样啊。在你的预料之中就继续访问以下代码内容吧。 我们都知道Li...
    99+
    2022-06-06
    android开发 gridview Android
  • Android studio 九宫格显示 gridview 适配器实现九宫格
    Android studio 九宫格显示 gridview 适配器实现九宫格 显示效果 Index.xml Item.xml Ind...
    99+
    2022-06-06
    Android Studio studio gridview Android
  • Android支付宝支付开发实例
    在移动应用满天飞的时代,随着移动支付的盛行,很多应用中都集成了支付功能。之前的支付一直不是我负责,近期这个项目我负责订单模块少不了要做支付,每每提起支付就觉得怕怕,觉得很难,但...
    99+
    2022-06-06
    Android
  • Android支付宝支付设计开发
         在移动支付领域,支付宝支付占用巨大份额,根据艾瑞咨询公布的报告数据:2014Q3,支付宝斩获了82.6%的市场份额,在移动支付...
    99+
    2022-06-06
    Android
  • Android实现图片九宫格
    本文实例为大家分享了Android实现图片九宫格的具体代码,供大家参考,具体内容如下 九宫格分三类 实现的效果 具体实现 activity_main <xml v...
    99+
    2024-04-02
  • Android实现九宫格抽奖
    本文实例为大家分享了Android实现九宫格抽奖的具体代码,供大家参考,具体内容如下 package cq.cake.luckdraw; import android.graph...
    99+
    2024-04-02
  • Android实现九宫格(GridView中各项平分空间)的方法
    本文实例讲述了Android实现九宫格(GridView中各项平分空间)的方法。分享给大家供大家参考。具体如下: 项目需要做一个九宫格(也不一定是9的,4宫格、16宫格、4x3...
    99+
    2022-06-06
    方法 gridview Android
  • Android 九宫格的实现方法
    1、xml代码: 代码如下:<xml version="1.0" encoding="utf-8">  <LinearLayout xmlns:an...
    99+
    2022-06-06
    方法 Android
  • Android RecyclerView实现九宫格效果
    RecyclerView更加优化的复用机制和方便实现UI效果,几乎替代Listview和GridView的使用。但是分割线的实现,需要自己继承ItemDecoration来绘制。 效...
    99+
    2024-04-02
  • Android 支付宝支付功能封装实现
      在做Android支付的时候肯定会用到支付宝支付, 根据官方给出的demo做起来非常费劲,所以我们需要一次简单的封装。封装的代码也很简单,是将官网给的demo提取出一个...
    99+
    2022-06-06
    封装 支付宝 Android
  • Android 实现九宫格抽奖功能
    目录效果展示实现步骤 1.生成抽奖矩形:2.添加奖品图片:3.实现抽奖动画:4.实现动态设置参数:5.添加抽奖结果回调效果展示 实现步骤 1.生成抽奖矩形: 其中每个矩形的宽高相...
    99+
    2024-04-02
  • Android怎么实现九宫格解锁
    这篇文章主要介绍Android怎么实现九宫格解锁,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!首先理清一下逻辑,我们要做NxN的九宫格 下图是3x3的简单图例// -(--)-(--)-(--)-// -(--)-(...
    99+
    2023-05-30
    android
  • Android实现九宫格图案解锁
    本文实例为大家分享了Android实现九宫格图案解锁的具体代码,供大家参考,具体内容如下 前言:自定义了一个九宫格的VIew来绘制九宫格图案,实现了绘制图案解锁的功能。 效果图如下:...
    99+
    2024-04-02
  • Android实现九宫格手势密码
    本文实例为大家分享了Android实现九宫格手势密码的具体代码,供大家参考,具体内容如下 介绍下自己编写的九宫格手势密码。先见图 思路:首先是9个格子,接着是格子连线;那么我们的步...
    99+
    2024-04-02
  • Android编程之九宫格实现方法实例分析
    本文实例讲述了Android编程之九宫格实现方法。分享给大家供大家参考,具体如下: 显示九宫格需要用GridView , 要显示每个格子中的视图有两种方式,第一种方式是做成xm...
    99+
    2022-06-06
    程之 方法 Android
  • Android实现九宫格解锁的方法
    相信大家都有使用九宫格解锁,比如在设置手机安全项目中,可以使用九宫格解锁,提高安全性,以及在使用支付功能的时候,为了提高安全使用九宫锁,今天就为大家介绍Android实现九宫格...
    99+
    2022-06-06
    方法 解锁 Android
  • Android 实现数字九宫格软键盘
    目录前言需求实现效果GIF实现代码使用方法前言 一开始大概是这种 需求 组长说 要不搞一个自定义软键盘吧 数字搞大点 方便外卖员输入数字 我设置了输入EditText的输入格式为...
    99+
    2024-04-02
  • Android中RecyclerView布局代替GridView实现类似支付宝的界面
    单纯使用GridView 通用的两种给GridView 添加分割线的方法;http://stackoverflow.com/questions/7132030/android-...
    99+
    2022-06-06
    界面 recyclerview gridview 支付宝 Android
  • Android实现支付宝支付密码输入界面
    本文实例为大家分享了Android实现支付宝支付密码输入界面的具体代码,供大家参考,具体内容如下 效果图: 主要代码: import java.util.ArrayList;   ...
    99+
    2024-04-02
  • 轻松实现安卓(Android)九宫格解锁
    效果图 思路 首先我们来分析一下实现九宫格解锁的思路:当用户的手指触摸到某一个点时,先判断该点是否在九宫格的某一格范围之内,若在范围内,则该格变成选中的状态;之后用户手指滑动...
    99+
    2022-06-06
    解锁 Android
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作