Android SlidingPaneLayout 实现新版 QQ 侧滑效果

本文深入探讨了如何在Android中使用Sliding Pane Layout组件,并详细阐述了其核心代码实现过程,包括背景设置、侧滑效果以及与Fragment的集成。通过实例解析,展示了如何利用该布局实现动态菜单与主内容区域的切换。
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <ImageView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:scaleType="fitXY"
            android:src="@drawable/bg" />
    </LinearLayout>

    <android.support.v4.widget.SlidingPaneLayout
        android:id="@+id/slidingPane"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@android:color/transparent">

        <FrameLayout
            android:id="@+id/layout_menu"
            android:layout_width="250dp"
            android:layout_height="match_parent" />

        <FrameLayout
            android:id="@+id/layout_content"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />

    </android.support.v4.widget.SlidingPaneLayout>
</FrameLayout>

首先重点是布局咯
FrameLayout 里面嵌套了两个布局
第一个是 LinearLayout 里面放了个 ImageView
这个布局的作用就是背景,用放 ImageView 就是为了可以设置缩放

第二个布局就是主角 SlidingPaneLayout 咯
里面放两个布局了这个侧滑就可以用了
这里用 FrameLayout 是为了可以用 Fragment
核心代码

        @Override
        public void onPanelSlide(View panel, float slideOffset) {
            int contentMargin = (int) (slideOffset * maxMargin);
            FrameLayout.LayoutParams contentParams = contentFragment
                    .getCurrentViewParams();

            contentParams.setMargins(0, contentMargin, 0, contentMargin);
            contentFragment.setCurrentViewPararms(contentParams);

            float scale = 1 - ((1 - slideOffset) * maxMargin * 2)
                    / (float) displayMetrics.heightPixels;
            menuFragment.getCurrentView().setScaleX(scale);// 设置缩放的基准点
            menuFragment.getCurrentView().setScaleY(scale);// 设置缩放的基准点
            menuFragment.getCurrentView().setPivotX(0);// 设置缩放和选择的点
            menuFragment.getCurrentView().setPivotY(
                    displayMetrics.heightPixels / 2);
            menuFragment.getCurrentView().setAlpha(slideOffset);
        }
物联网通信协议测试是保障各类设备间实现可靠数据交互的核心环节。在众多适用于物联网的通信协议中,MQTT(消息队列遥测传输)以其设计简洁与低能耗的优势,获得了广泛应用。为确保MQTT客户端与服务端的实现严格遵循既定标准,并具备良好的互操作性,实施系统化的测试验证至关重要。 为此,采用TTCN-3(树表结合表示法第3版)这一国际标准化测试语言构建的自动化测试框架被引入。该语言擅长表达复杂的测试逻辑与数据结构,同时保持了代码的清晰度与可维护性。基于此框架开发的MQTT协议一致性验证套件,旨在自动化地检验MQTT实现是否完全符合协议规范,并验证其与Eclipse基金会及欧洲电信标准化协会(ETSI)所发布的相关标准的兼容性。这两个组织在物联网通信领域具有广泛影响力,其标准常被视为行业重要参考。 MQTT协议本身存在多个迭代版本,例如3.1、3.1.1以及功能更为丰富的5.0版。一套完备的测试工具必须能够覆盖对这些不同版本的验证,以确保基于各版本开发的设备与应用均能满足一致的质量与可靠性要求,这对于物联网生态的长期稳定运行具有基础性意义。 本资源包内包含核心测试框架文件、一份概述性介绍文档以及一份附加资源文档。这些材料共同提供了关于测试套件功能、应用方法及可能包含的扩展工具或示例的详细信息,旨在协助用户快速理解并部署该测试解决方案。 综上所述,一个基于TTCN-3的高效自动化测试框架,为执行全面、标准的MQTT协议一致性验证提供了理想的技术路径。通过此类专业测试套件,开发人员能够有效确保其MQTT实现的规范符合性与系统兼容性,从而为构建稳定、安全的物联网通信环境奠定坚实基础。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值