高仿QQ5.0的侧滑菜单的实现

本文介绍了通过学习张鸿洋的教程实现QQ风格侧滑菜单的过程。主要内容涵盖自定义布局、添加菜单动画及使用特定jar包等关键技术点。

转载自:http://blog.youkuaiyun.com/lmj623565791/article/details/39257409【张鸿洋的博客】

偶遇

看到QQ的侧滑菜单的效果,感觉真的很酷炫,想找一些高仿的源码,看了之后,发现根本不懂,所以放弃了,但是偶然的机会让我认识了张鸿洋,看到了他的视频我就会了,也不能说是会了,准确说是会用了,明白它的实现原理,知道怎么移植到自己的程序中,对我现在的情况来说算是不错的结果了。

深知

仔细的看了他的视频,真是每一行代码敲给你看,一行一行的来,不能保证你完全懂,但是保证你能做出来,所以我还是怀着感激的心情来给他打个广告.。
下面我简单说明一下大思路,在于提醒自己如何实现这个效果,如果真的想实现或者学会它,大家还是看他的视频吧!
  1. 添加菜单的布局文件 left_menu.xml,在这个文件里面我们设置自己想要的布局内容,如我的布局是下面的效果(抄袭张的^_^)

    至于Xml文件我就不贴上去了,太难看,稍后我把代码给大家,有兴趣的大家可以自己去看看。
  2. 新建一个类:
    public class SlidingMenu extends HorizontalScrollView{}

    我们稍后的操作都是在这个类里面实现,包括菜单的打开,关闭,动画效果等等

  3. 自定义属性
    我们需要在values文件夹下新建一个文件:attr.xml,内容如下:


    <?xml version="1.0" encoding="utf-8"?>
    <resources>
        <attr name="rightPadding" format="dimension"></attr>
        <declare-styleable name="SlidingMenu">
            <attr name="rightPadding"></attr>
        </declare-styleable>
    </resources>
    

    在这个文件里面,我们给SlideMenu添加了一个自定义的属性:rightPadding,这个属性是说,我的格式是dimension,所以你赋值的时候是 "50dp" 这种格式的内容,这个属性的作用是设置菜单向右的偏移距离。
    然后我们必须要使用这个属性,在activity_main.xml文件中使用它,下面是我的activity_main.xml的代码


    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        xmlns:pjc="http://schemas.android.com/apk/res/com.example.qqslidemenu"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:context="com.example.qqslidemenu.MainActivity" >
        
        <com.example.qqslidemenu.SlidingMenu
            android:id="@+id/slidingMenu" 
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:scrollbars="none"
            android:background="@drawable/bg"
            pjc:rightPadding="100dp"
            android:overScrollMode="never"
            >
            <LinearLayout 
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:orientation="horizontal"
                >
                <include 
                    layout="@layout/left_menu"
                    android:id="@+id/leftMenuLayout" 
                    />
                <LinearLayout
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:background="@drawable/main"
                    >
                    <Button
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:onClick="toggleMenu"
                        android:text="菜单"
                        android:textColor="#ff00ff"
                        style="?android:attr/buttonBarButtonStyle"
                        />
                </LinearLayout>
            </LinearLayout>
        </com.example.qqslidemenu.SlidingMenu>
    </RelativeLayout>
    

    使用的时候,我们需要设置命名空间,xmlns:pjc="http://schemas.android.com/apk/res/com.example.qqslidemenu" 看代码中的这条代码,我们设置了命名空间pjc,从com.example.qqsqlidemenu之前的都是一样的,com.example.qqsqlidemenu是我们当前应用的包名。
    pjc:rightPadding="100dp"  然后我们就可以使用它了,设置菜单的偏移距离。
  4. 我们在SlidingMenu中实现菜单的动画时需要使用一个jar包,我们必须把这个jar包导入到我们的工程中才可以。

    nineoldandroids-2.4.0.jar

    这个jar包在我的源码中有,大家可以下载使用。


感悟

关于在SlidingMenu中的具体操作,我就不做说明了,东西太多,好多我也不是太明白,忘的时候我就去看看张的视频,写这个简短的文章的目的主要是说明一下实现的思路,然后看看代码就可以知道当时是怎么是实现的,算是一个提醒作用吧。^_^
下载源码

基于51单片机,实现对直流电机的调速、测速以及正反转控制。项目包含完整的仿真文件、源程序、原理图和PCB设计文件,适合学习和实践51单片机在电机控制方面的应用。 功能特点 调速控制:通过按键调整PWM占空比,实现电机的速度调节。 测速功能:采用霍尔传感器非接触式测速,实时显示电机转速。 正反转控制:通过按键切换电机的正转和反转状态。 LCD显示:使用LCD1602液晶显示屏,显示当前的转速和PWM占空比。 硬件组成 主控制器:STC89C51/52单片机(与AT89S51/52、AT89C51/52通用)。 测速传感器:霍尔传感器,用于非接触式测速。 显示模块:LCD1602液晶显示屏,显示转速和占空比。 电机驱动:采用双H桥电路,控制电机的正反转和调速。 软件设计 编程语言:C语言。 开发环境:Keil uVision。 仿真工具:Proteus。 使用说明 液晶屏显示: 第一行显示电机转速(单位:转/分)。 第二行显示PWM占空比(0~100%)。 按键功能: 1键:加速键,短按占空比加1,长按连续加。 2键:减速键,短按占空比减1,长按连续减。 3键:反转切换键,按下后电机反转。 4键:正转切换键,按下后电机正转。 5键:开始暂停键,按一下开始,再按一下暂停。 注意事项 磁铁和霍尔元件的距离应保持在2mm左右,过近可能会在电机转动时碰到霍尔元件,过远则可能导致霍尔元件无法检测到磁铁。 资源文件 仿真文件:Proteus仿真文件,用于模拟电机控制系统的运行。 源程序:Keil uVision项目文件,包含完整的C语言源代码。 原理图:电路设计原理图,详细展示了各模块的连接方式。 PCB设计:PCB布局文件,可用于实际电路板的制作。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值