恭喜发财! -- 手把手教你仿造一个qq下拉抢红包 Android自定义view

猴年猴赛雷啊各位,今天没吃药我感觉自己萌萌哒!

qq和微信和支付宝红包大战,不知道各位的战绩是多少嘞? 反正我qq抢到的都是气泡。因为太不爽,所以自己写一个下拉抢红包自己玩(自己跟自己玩)。

先来看效果图。这个…… 呃~~ -__-” 。。有点丑 是低仿。
这里写图片描述

转载请注明出处:http://blog.csdn.net/wingichoy/article/details/50662592

学习完本篇博客你能获得到的知识

  1. 正确的获得view的大小
  2. listview的下拉header
  3. 自定义字体
  4. 自己添加监听器

废话不多说,快跟我来一起动手

  • 首先来跟我打造一个自定义的listview

新建一个类,继承自listview,这里需要来重写一下他的overScrollBy()方法。

public class HBListView extends ListView {
   

    //header显示的图片
    private MyImageView mImageView;
    private Context mContext;
    //抢到红包时候的监听器
    private OnSuccessListener mOnSuccessListener;


    @Override
    protected boolean overScrollBy(int deltaX, int deltaY, int scrollX, int scrollY, int scrollRangeX, int scrollRangeY, int maxOverScrollX, int maxOverScrollY, boolean isTouchEvent) {
        Log.e("wing", "deltaY:" + deltaY + " scrollY:" + scrollY);
        return super.overScrollBy(deltaX, deltaY, scrollX, scrollY, scrollRangeX, scrollRangeY, maxOverScrollX, maxOverScrollY, isTouchEvent);

    }

先来介绍一下重要参数的意思

deltaX,Y是指速度值,也就是你手指滑动的瞬时速度。
scrollX,Y 水平和数值方向上的变化量
isTouchEvent 表示手指是否在触摸状态

观察log可以轻易看到他们与手机触摸的关系。大家自己试验一下就可以。

接着给listview加一个header

mListView = (HBListView) findViewById(R.id.lv);

        final View header = LayoutInflater.from(this).inflate(R.layout.view_header,null);
        mListView.addHeaderView(header);

其实这个header就是个图片。 我们刚才从listview的监听上面看到了偏移量。所以可以根据偏移量来动态改变图片的大小。

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

    <com.wingsofts.hongbao.MyImageView
        android:id = "@+id/imageView"
        android:scaleType="centerCrop"
        android:layout_width="m
  • 19
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 18
    评论
微信抢红包算法涉及到微信支付和微信红包接口的调用,需要进行授权认证和支付操作,因此需要使用微信官方提供的SDK进行发。 以下是一个基本的微信抢红包算法的示例代码: ```php <?php require_once "WxPayApi.php"; // 引入微信支付SDK // 微信支付配置参数 $config = new WxPayConfig(); $config->SetAppId("YOUR_APPID"); $config->SetMchId("YOUR_MCHID"); $config->SetKey("YOUR_KEY"); $config->SetNotifyUrl("YOUR_NOTIFY_URL"); // 获取红包信息 $redpack = $_POST["redpack"]; // 前端传递的红包信息 $redpack_info = json_decode($redpack, true); // 解析红包信息 // 构造红包支付请求参数 $input = new WxPayUnifiedOrder(); $input->SetBody("红包支付"); // 商品描述 $input->SetOut_trade_no($redpack_info["redpack_id"]); // 商户订单号 $input->SetTotal_fee($redpack_info["total_amount"] * 100); // 总金额,单位为分 $input->SetSpbill_create_ip($_SERVER["REMOTE_ADDR"]); // 终端IP $input->SetNotify_url($config->GetNotifyUrl()); // 通知地址 $input->SetTrade_type("JSAPI"); // 交易类型 $input->SetOpenid($redpack_info["openid"]); // 用户标识 // 调用统一下单API获取预支付交易会话标识 $wxpay_api = new WxPayApi($config); $result = $wxpay_api->unifiedOrder($input); if ($result["return_code"] == "SUCCESS" && $result["result_code"] == "SUCCESS") { // 构造红包接口请求参数 $redpack_input = new WxPayRedPack(); $redpack_input->SetMch_billno($redpack_info["redpack_id"]); // 商户订单号 $redpack_input->SetSend_name("微信红包"); // 商户名称 $redpack_input->SetRe_openid($redpack_info["openid"]); // 用户openid $redpack_input->SetTotal_amount($redpack_info["total_amount"] * 100); // 付款金额,单位为分 $redpack_input->SetTotal_num(1); // 红包发放总人数 $redpack_input->SetWishing("恭喜发财,大吉大利"); // 红包祝福语 $redpack_input->SetClient_ip($_SERVER["REMOTE_ADDR"]); // Ip地址 $redpack_input->SetAct_name("微信红包"); // 活动名称 $redpack_input->SetRemark("微信红包"); // 备注信息 // 调用红包接口发放红包 $result = $wxpay_api->sendRedPack($redpack_input); if ($result["return_code"] == "SUCCESS" && $result["result_code"] == "SUCCESS") { echo "红包发送成功!"; } else { echo "红包发送失败!"; } } else { echo "统一下单失败!"; } ``` 需要注意的是,该示例代码仅供参考,实际发中需要根据具体业务场景进行适当的修改和调整。另外,微信红包接口需要在微信商户平台进行通和配置,具体操作请参考微信官方文档和发者文档。
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值