用小程序做一个类似于苹果AssistiveTouch功能

一、首先我先介绍一下,我们要做一个什么样的项目功能

   项目功能就是一个音频点击播放,当点击为播放的状态时,一个音频的动图出现,而且是可以跟随着手指的滑动而滑动,而且,在滑动动图的时候,当前下的页面是不可以跟随着我的滑动而上下滚动,当停止滑动的时候,音频动图停靠在手机的左侧或者右侧,而当前下的页面是可以上下滚动的,功能介绍到此为止,下面我们说一下思路。

二、我们做这个功能,第二步就是要想思路

思路就是,利用微信中的滑动事件,外加控制css样式,来完成这个功能。

三、这是项目的ui图,废话不多说,直接撸代码。

项目样图



四、index.wxml、index.wxss、index.js页面代码

*index.wxml页面*
<!-- 搜索 -->

    <view class=‘home_srh‘>
        <view class=‘srh_box‘ bindtap=‘srhBox‘>
            <image class=‘srh_box_img‘ src=‘../../img/home_search.png‘></image>
            <view class=‘srh_box_text‘>开心奶奶</view>
        </view>
    </view>

    <!-- 音频分类 -->

    <view class=‘home_ban‘>

        <!-- 轮播图 -->
        <view class="page-section">
        <swiper circular="true" previous-margin="44rpx" next-margin="44rpx">
            <!-- <block wx:for="{{}}" wx:key=""> -->
            <swiper-item>
                <view class="swiper-item">
                    <audio src="http://img.tukuppt.com/preview_music/00/00/60/yulan-5b87c00c59d402663.mp3" id="myAudio" loop></audio>
                    <view class=‘audio_box‘>
                        <button bindtap=‘audioPlay‘ wx:if="{{adply1}}" class=‘audio_play‘>
                            <image  src=‘../../img/home_adplay.png‘ ></image>
                        </button>
                        <button bindtap=‘audioPause‘ wx:if="{{adply2}}" class=‘audio_play‘>
                            <image  src=‘../../img/home_adstop.png‘ ></image>
                        </button>
                    </view>
                    <view class=‘audio_next‘>
                        <image src=‘../../img/audio_next.png‘></image>
                    </view>
                    <view class=‘audio_collect‘>
                        <button bindtap=‘audioColy‘ wx:if="{{adcol1}}" class=‘audio_coly‘>
                            <image src=‘../../img/audio_nocollect.png‘></image>
                        </button>
                        <button bindtap=‘audioColn‘ wx:if="{{adcol2}}" class=‘audio_coly‘>
                            <image src=‘../../img/audio_collect.png‘></image>
                        </button>
                    </view>
                    <view class=‘audio_text‘>开心奶奶——小小探险家</view>
                </view>
            </swiper-item>
            <swiper-item>
                <view class="swiper-item">
                    <audio src="http://img.tukuppt.com/preview_music/00/00/60/yulan-5b87c00c59d402663.mp3" id="myAudio" loop></audio>
                    <view class=‘audio_box‘>
                        <button bindtap=‘audioPlay‘ wx:if="{{adply1}}" class=‘audio_play‘>
                            <image  src=‘../../img/home_adplay.png‘ ></image>
                        </button>
                        <button bindtap=‘audioPause‘ wx:if="{{adply2}}" class=‘audio_play‘>
                            <image  src=‘../../img/home_adstop.png‘ ></image>
                        </button>
                    </view>
                    <view class=‘audio_next‘>
                        <image src=‘../../img/audio_next.png‘></image>
                    </view>
                    <view class=‘audio_collect‘>
                        <button bindtap=‘audioColy‘ wx:if="{{adcol1}}" class=‘audio_coly‘>
                            <image src=‘../../img/audio_nocollect.png‘></image>
                        </button>
                        <button bindtap=‘audioColn‘ wx:if="{{adcol2}}" class=‘audio_coly‘>
                            <image src=‘../../img/audio_collect.png‘></image>
                        </button>
                    </view>
                    <view class=‘audio_text‘>开心奶奶——小小探险家</view>
                </view>
            </swiper-item>
            <!-- </block> -->
            </swiper>

        </view>

----------

> 重点!!!!

        <!-- 音频动图 -->
        <view class=‘{{ home_back }}‘ catchtouchmove=‘true‘ >
            <view class=‘audio_fre‘  wx:if="{{ adFre }}" bindtouchmove="handletouchmove" bindtouchend="handletouchend" style = "top:{{top}}px; left: {{left}}px; right: {{right}}px">
                <image class=‘audio_fre1‘ src=‘../../img/audio_back.png‘></image>
                <image class=‘audio_fre2‘ src=‘../../img/audio_fre.gif‘></image>
            </view>
        </view>

----------

        <!-- 分类 -->
        <view class=‘menu_ul‘>
            <view class=‘menu_li‘ id="0" bindtap=‘menuLi‘>
                <image src=‘../../img/recom.png‘></image>
                <view class=‘menu_text‘>推荐故事</view>
            </view>
            <view class=‘menu_li‘ id="1" bindtap=‘menuLi‘>
                <image src=‘../../img/boy_icon.png‘></image>
                <view class=‘menu_text‘>男孩</view>
            </view>
            <view class=‘menu_li‘ id="2" bindtap=‘menuLi‘>
                <image src=‘../../img/girl_icon.png‘></image>
                <view class=‘menu_text‘>女孩</view>
            </view>
        </view>

    </view>

    <!-- 儿童故事 -->
    <view class=‘child_story‘>
        <view class=‘story_ul‘ wx:if="{{curr_index == 0}}">
            <view class=‘story_li‘ bindtap=‘storySec‘>
                <view class=‘story_li_img‘>
                    <image class=‘story_li_img1‘ src=‘../../img/weekend-first.png‘></image>
                    <image class=‘story_li_img2‘ src=‘../../img/pay_icon.png‘></image>
                </view>
                <view class=‘st_li_tit b‘>童话故事里的小智慧</view>
                <view class=‘st_li_sec‘>小智慧,大智慧</view>
            </view>
        </view>
        <view class=‘story_ul‘ wx:if="{{curr_index == 1}}">
            <view class=‘story_li‘ bindtap=‘storySec‘>
                <view class=‘story_li_img‘>
                    <image class=‘story_li_img1‘ src=‘../../img/weekend-first.png‘></image>
                    <!-- <image class=‘story_li_img2‘ src=‘../../img/pay_icon.png‘></image> -->
                </view>
                <view class=‘st_li_tit b‘>童话故事里的小智慧</view>
                <view class=‘st_li_sec‘>小智慧,大智慧</view>
            </view>
        </view>
        <view class=‘story_ul‘ wx:if="{{curr_index == 2}}">
            <view class=‘story_li‘ bindtap=‘storySec‘>
                <view class=‘story_li_img‘>
                    <image class=‘story_li_img1‘ src=‘../../img/weekend-first.png‘></image>
                    <image class=‘story_li_img2‘ src=‘../../img/pay_icon.png‘></image>
                </view>
                <view class=‘st_li_tit b‘>童话故事里的小智慧</view>
                <view class=‘st_li_sec‘>小智慧,大智慧</view>
            </view>
        </view>
    </view>
*index.wxss样式*
/**index.wxss**/

.home_back1{
    width: 100%;
}

.home_back2{
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 10;
}

/* 搜索 */
.home_srh {
    width: 100%;
    height: 74rpx;
    padding-top: 20rpx;
    background: #fff;
    border-bottom: 1rpx solid #e8e8e8;
}

.home_srh .srh_box {
    width: 690rpx;
    height: 54rpx;
    margin: 0 auto;
    box-shadow: 0 0 10rpx 2rpx #f1f1f1;
    border-radius: 50rpx;
    display: flex;
    align-items: center;
}

.home_srh .srh_box .srh_box_img {
    width: 24rpx;
    height: 26rpx;
    display: inline-block;
    margin-left: 32rpx;
    margin-right: 20rpx;
}

.home_srh .srh_box .srh_box_text {
    font-size: 24rpx;
    color: #999;
}

/* 音频分类 */

/* banner图 */
.home_ban{
    width: 100%;
    height: 422rpx;
    background: #fff;
    padding-top: 18rpx;
}

.home_ban .page-section{
    width: 100%;
    height: 258rpx;
    position:relative;
    z-index: 2;
}

.home_ban .page-section .swiper-item{
    width: 630rpx;
    height: 258rpx;
    margin: 0 auto;
    position: relative;
    display: block;
}

.home_ban .page-section .swiper-item audio{
    width: 630rpx;
    height: 258rpx;
    display: block;
    background: #ccc;

}

.home_ban .page-section .swiper-item .audio_box {
    width: 90rpx;
    height: 90rpx;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: -45rpx;
    margin-top: -45rpx;
}

.home_ban .page-section .swiper-item .audio_box .audio_play {
    width: 90rpx;
    height: 90rpx;
    display: block;
    background: rgba(0,0,0,0);
}

.home_ban .page-section .swiper-item .audio_box .audio_play image{
    width: 90rpx;
    height: 90rpx;
    display: block;
}

.home_ban .page-section .swiper-item .audio_next {
    width: 60rpx;
    height: 60rpx;
    position: absolute;
    top: 50%;
    margin-top: -30rpx;
    right: 169rpx;
}

.home_ban .page-section .swiper-item .audio_next image {
    width: 60rpx;
    height: 60rpx;
    display: block;
}

.home_ban .page-section .swiper-item .audio_collect {
    width: 60rpx;
    height: 60rpx;
    position: absolute;
    top: 50%;
    margin-top: -30rpx;
    right: 169rpx;
}

.home_ban .page-section .swiper-item .audio_collect image {
    width: 60rpx;
    height: 60rpx;
    display: block;
}

.home_ban .page-section .swiper-item .audio_collect {
    width: 60rpx;
    height: 60rpx;
    position: absolute;
    top: 50%;
    margin-top: -30rpx;
    left: 169rpx;
}

.home_ban .page-section .swiper-item .audio_collect .audio_coly {
    width: 60rpx;
    height: 60rpx;
    display: block;
    background: rgba(0,0,0,0);
}

.home_ban .page-section .swiper-item .audio_collect .audio_coly image {
    width: 60rpx;
    height: 60rpx;
    display: block;
}

.home_ban .page-section .swiper-item .audio_text{
    width: 100%;
    font-size: 28rpx;
    color: #fff;
    text-align: center;
    position: absolute;
    bottom: 26rpx;
}

/* 音频小白点 */

.audio_fre {
    width: 108rpx;
    height: 108rpx;
    position: fixed;
    z-index: 99;
}

.audio_fre .audio_fre1 {
    width: 104rpx;
    height: 104rpx;
    display: block;
    border-radius: 100%;
    border: 2rpx solid #fff;
}

.audio_fre .audio_fre2 {
    width: 60rpx;
    height: 60rpx;
    position: absolute;
    top: 50%;
    margin-top: -30rpx;
    left: 50%;
    margin-left: -30rpx;
}

/* 菜单分类 */
.menu_ul {
    width: 100%;
    height: 164rpx;
}

.menu_ul .menu_li {
    width: 33.3%;
    height: 164rpx;
    float: left;
    text-align: center;
}

.menu_ul .menu_li:nth-child(1) image{
    width: 78rpx;
    height: 80rpx;
    display: block;
    margin: 0 auto;
    margin-top: 23rpx;
}

.menu_ul .menu_li:nth-child(2) image{
    width: 74rpx;
    height: 97rpx;
    display: block;
    margin: 0 auto;
    margin-top: 8rpx;
}

.menu_ul .menu_li:nth-child(3) image{
    width: 73rpx;
    height: 96rpx;
    display: block;
    margin: 0 auto;
    margin-top: 8rpx;
}

.menu_ul .menu_li .menu_text{
    width: 100%;
    text-align: center;
    font-size: 24rpx;
    color: #343434;
    margin-top: 10rpx;
}

/* 儿童故事 */
.child_story {
    width: 100%;
    margin-top: 8rpx;
    background: #fff;
} 

.child_story .story_ul {
    padding: 0 32rpx;
    padding-top: 30rpx;
    overflow: hidden;
}

.child_story .story_ul .story_li {
    width: 330rpx;
    float: left;
    margin-right: 26rpx;
    margin-bottom: 30rpx;
}

.child_story .story_ul .story_li:nth-child(2n) {
    margin-right: 0;
}

.child_story .story_ul .story_li .story_li_img {
    width: 330rpx;
    height: 210rpx;
    border-radius: 14rpx;
    position: relative;
    overflow: hidden;
}

.child_story .story_ul .story_li .story_li_img .story_li_img1{
    width: 330rpx;
    height: 210rpx;
    display: block;
}

.child_story .story_ul .story_li .story_li_img .story_li_img2{
    width: 95rpx;
    height: 32rpx;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
}

.child_story .story_ul .story_li .st_li_tit {
    width: 90%;
    font-size: 26rpx;
    color: #212121;
    margin-top: 18rpx;
    padding: 0 5%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    letter-spacing: 0.4rpx;
}

.child_story .story_ul .story_li .st_li_sec {
    width: 90%;
    font-size: 18rpx;
    color: #999;
    margin-top: 6rpx;
    padding: 0 5%;
    letter-spacing: 0.2rpx;
}
*index.js页面*
//index.js
var app = getApp();
Page({

    /**
     * 页面的初始数据
     */
    data: {
        adply1: true,
        adply2: false,
        adcol1: true,
        adcol2: false,
        adFre: false,
        funBun: false,
        curr_index: 0,
        screenHeight: 0,
        screenWidth: 0,
        top: 65,
        left: 300,
        right: 0,
        home_back: ‘home_back1‘
    },

    /**
     * 生命周期函数--监听页面加载
     */
    onLoad: function (options) {
        //获取屏幕宽高
        var that = this;
        wx.getSystemInfo({
            success: function (res) {
                console.log(res.windowWidth)//手机可用屏幕宽度
                console.log(res.windowHeight)//手机可用屏幕高度
                that.setData({
                    screenHeight: res.windowHeight,
                    screenWidth: res.windowWidth,
                });
            }
        });
    },

    /**
     * 生命周期函数--监听页面初次渲染完成
     */
    onReady: function (e) {
        let that = this;
        that.audioCtx = wx.createAudioContext(‘myAudio‘)
    },

    /**
     * 生命周期函数--监听页面显示
     */
    onShow: function () {

    },

    /**
     * 生命周期函数--监听页面隐藏
     */
    onHide: function () {

    },

    /**
     * 生命周期函数--监听页面卸载
     */
    onUnload: function () {

    },

    /**
     * 页面相关事件处理函数--监听用户下拉动作
     */
    onPullDownRefresh: function () {

    },

    /**
     * 页面上拉触底事件的处理函数
     */
    onReachBottom: function () {

    },

    /**
     * 用户点击右上角分享
     */
    onShareAppMessage: function () {

    },

    /**
     * 跳转搜索页面
     */
    srhBox: function () {
        let that = this;
        wx.navigateTo({
            url: ‘../search/index‘,
        })
    },

    /**
     * 点击播放
     */
    audioPlay: function () {
        var that = this;
        that.audioCtx.play();
        that.setData({
            adply1: false,
            adply2: true,
            adFre: true,
            // isScroll: that.data.isScroll
        })
    },

    /**
     * 点击暂停
     */
    audioPause: function () {
        var that = this;
        that.audioCtx.pause();
        that.setData({
            adply1: true,
            adply2: false,
            adFre: false,
            // isScroll: that.data.isScroll
        })
    },  

    /**
    * 点击收藏
    */
    audioColy: function () {
        var that = this;
        that.setData({
            adcol1: false,
            adcol2: true,
        })
    },

    /**
     * 点击未收藏
     */
    audioColn: function () {
        var that = this;
        that.setData({
            adcol1: true,
            adcol2: false,
        })
    },  

    /**
     * 跳转故事详情
     */

    storySec: function () {
        let that = this;
        wx.navigateTo({
            url: ‘../audio/index‘,
        })
    },

    /**
     * 点击切换
     */

    menuLi: function (e) {
        let that = this;
        // console.log (e);
        let id = e.currentTarget.id;

        that.setData({
            curr_index: id
        })
    },

    /**
     * 音频小白点滑动
     */

    //滑动移动事件
    handletouchmove: function (e) {
        let that = this;
        let clientX = e.touches[0].clientX;
        let clientY = e.touches[0].clientY;
        //屏幕边界判断
        if (clientX < 20 || clientY < 20)
            return;
        if (clientX > that.data.screenWidth - 20)
            return;
        if (clientY > that.data.screenHeight - 20)
            return;
        that.setData({
            left: e.touches[0].clientX - 20,
            top: e.touches[0].clientY - 20,
            right: e.touches[0].clientX - 20,
            home_back: ‘home_back2‘
        })

    },

    //滑动结束事件
    handletouchend: function (e) {
        let that = this;
        if ( that.data.left < (that.data.screenWidth - 60) / 2 ) {
            that.setData({
                left: 0,
                home_back: ‘home_back1‘
            })
        } else {
            that.setData({
                left: that.data.screenWidth - 60,
                right: 0,
                home_back: ‘home_back1‘
            })
        }
    }

})

原文地址:https://www.cnblogs.com/jlfw/p/11830771.html

时间: 2024-08-25 19:07:23

用小程序做一个类似于苹果AssistiveTouch功能的相关文章

小程序做一个能够左右滑动切换的多tab页面

主要原理:使用 <swiper> 和 <scroll-view> 组件 代码片段: https://developers.weixin.qq.com/s/mLx4FWmF757Z GitHub: github.com/WozHuang/Miniprogram-Demo 小程序是轻量级的app,本应小巧精悍.用完即走,但是很多企业还是想要在这辆自行车上装发动机,要求拥有原生APP的操作体验.作为一介码农也只能默默想办法实现了,总不能说这东西我不想做吧 有兴趣可以在Github看看另外

微信小程序学习Course 9 云开发功能

微信小程序学习Course 9 云开发功能 微信小程序提供了一套免费的云开发功能API函数,虽然容量小,但足够我们个人用户使用以及学习了.下面简单介绍一下. 云开发为开发者提供完整的云端支持,弱化后端和运维概念,无需搭建服务器,使用平台提供的 API 进行核心业务开发,即可实现快速上线和迭代,同时这一能力,同开发者已经使用的云服务相互兼容,并不互斥. 目前提供三大基础能力支持: 云函数:在云端运行的代码,微信私有协议天然鉴权,开发者只需编写自身业务逻辑代码 数据库:一个既可在小程序前端操作,也能

小程序 - 实现【一键复制】功能

小程序 - 实现[一键复制]功能 为啥想起使用[一键复制]功能?因为个人小程序里,不许加外链接,很是头疼,就想到一键复制链接,这是我刚写的一个减一的小程序: 使用[一键复制]: wxml 文件: <view> 官网:<text selectable='true' bindlongtap='copy' >{{url}}</text> <!-- 注意,上面只是一个提示功能 --> <button bindtap="copyBtn">

如何使用微信小程序开发一个弹窗页面(附源码)

在小程序的开发过程中,我们肯定会遇到开发一个弹窗页面的情况,我们先看一下小程序官方对于弹窗页面的解释.API的接口如下 从官方给出的代码示例来看,想当简单,就像一个asert,并不能看出弹窗的真实需求.所以今天HTML51.COM就写了一个弹窗小程序教程,供大家学习参考.首页我们先看一下动态的效果图: 我们首先看到的是首页代码: <view class="copyright"> <view class="copyright_item">Cop

小程序即时聊天(仅页面功能,未接websocket)

我们都知道小程序是不能直接操作dom的,所以做即时通讯聊天功能的时候也就不能像之前做的一样:点击发送的时候,拼接一个节点到页面上.话不多说,以下是效果和代码: -----------------------chat.js------------------------------ // pages/chat/chat.js Page({ /** * 页面的初始数据 */ data: { lists: [ ], scrollTop: 100,//设置滚动条到顶部的距离 centence:'', l

微信小程序开发—你期待的分享功能来了,微信小程序序新增5大功能

微信小程序在12月21日发布了新版本的开发工具,并在官网公布新增分享.模板消息.客服消息.扫一扫.带参数二维码功能. 有了分享功能,相信会给很多创业者带来了无限的可能性! 下面就来看看这些新功能到底怎么用吧! 1.分享 可以分享小程序的任何一个页面给好友或群聊.注意是分享给好友或群聊,并没有分享到朋友圈.一方面微信在尝试流量分发方式,但同时又不愿意开放最大的流量入口. 开发文档:https://mp.weixin.qq.com/debug/wxadoc/dev/api/share.html?t=

微信小程序实现点赞、取消点赞功能

最近接触到小程序,发现很有意思,在项目中遇到了一点小问题,就是点赞+取消点赞有些冲突,还有就是多项的点击,话不多说咱们直接上代码! 效果图 wxml ? 1 2 3 4 5 <block wx:for="{{msg}}"> <image class='imgList' hidden='{{item.show}}' bindtap='zan' data-index='{{index}}' src='../resizeApi.png'></image>

小程序从一个页面样式 传递到另一个页面的样式

1 onSubmit() { 2 //定义一个空数组 3 let activeLabel = [] 4 this.data.lableList.map((item)=>{ 5 if(item.activeIndex != null){ 6 //获取到child的所需携带的索引值,赋值给标签 7 let label = item.child[item.activeIndex] 8 label.type = item.type 9 activeLabel.push(label) 10 } 11 })

微信小程序入门一个

1.index.wxml内容如下: <!--index.wxml--> <view class="container"> <form bindsubmit="formSubmit" bindreset="formReset"> <view class="section"> <text>远上寒山石径斜,__________________.</text> &