js模仿ios select效果

github:https://github.com/zhoushengmufc/iosselect

webapp模仿ios下拉菜单

html下拉菜单select在安卓和IOS下表现不一样,iosselect正是为统一下拉菜单样式而生

我们以IOS下select的交互和样式为蓝本,开发了这一组件

先看效果:

特点

可以做到0依赖,只需引用一个js和css即可,样式可自己定制,也可使用默认样式

文件说明

src------iosselect基于iscroll5开发,在这个文件夹下可以看到iscroll.js,iosselect.js,iosselect.css,如果项目里有单独使用iscroll5,可以使用这个版本

merge------合并了iscroll与iosselect,做到组件0依赖,方便开发

demo------使用demo,说明如下:

one------一级下拉菜单,以银行选择为实例

two------二级下拉菜单,相互独立,没有关联,以三国杀组合选将为例

three------三级下拉菜单,省市区选择三级联动

rem------手机端部分解决方案会使用viewport缩放,这个时候我们需要添加一些样式,页面在缩放的情况下正常显示

使用说明

###API
new IosSelect(level, data, options)
level: 选择的层级 1 2 3 最多支持3层
data: [oneLevelArray[, twoLevelArray[, threeLevelArray]]]
options:
     callback: 选择完毕后的回调函数 必选
     title: 选择框title  可选,没有此参数则不显示title
     itemHeight: 每一项的高度,可选,默认 35px
     headerHeight: 组件标题栏高度 可选,默认 44px
     addClassName: 组件额外类名 可选,用于自定义样式
     oneTwoRelation: 第一列和第二列是否通过parentId关联 可选,默认不关联
     twoThreeRelation: 第二列和第三列是否通过parentId关联 可选,默认不关联
     oneLevelId: 第一级选中id 可选
     twoLevelId: 第二级选中id 可选
     threeLevelId: 第三级选中id 可选
####参数说明
level: 级联等级,支持1,2,3 必选项
data: 数组,前三项分别对应级联1,2,3项,每一项又是一个数组,如果是一级下拉菜单,data长度为1

    每一项数组中包含一系列对象,每个对象必须要有id,作为该条数据在该项数组中的唯一标识,parentId是可选属性,作为关联的标志
options.callback(selectOneObj[[, selectTwoObj], selectThreeObj]) 每个级联选中项,包含对应数据的所有字段及dom对象
####以地址选择为例:
data为三个数组:
// 省份列表
var iosProvinces = [
    {'id': '130000', 'value': '河北省', 'parentId': '0'}
];

// 城市列表
var iosCitys = [
    {"id":"130100","value":"石家庄市","parentId":"130000"}
];

// 区县列表
var iosCountys = [
    {"id":"130102","value":"长安区","parentId":"130100"}
];
实例化:
var iosSelect = new IosSelect(3, 
        [iosProvinces, iosCitys, iosCountys],
        {
            title: '地址选择',
            itemHeight: 35,
            oneTwoRelation: 1,
            twoThreeRelation: 1,
            oneLevelId: oneLevelId,
            twoLevelId: twoLevelId,
            threeLevelId: threeLevelId,
            callback: function (selectOneObj, selectTwoObj, selectThreeObj) {
                selectOneObj = {
                    atindex:26,
                    dom:li.at,
                    id:"510000",
                    parentid:"0",
                    value:"四川省"
                }
            }
    });

demo说明

一级级联,银行选择

http://zhoushengfe.com/iosselect/demo/one/bank.html

二级级联,三国杀将领组合选

http://zhoushengfe.com/iosselect/demo/two/sanguokill.html

三级级联,省市区选择

http://zhoushengfe.com/iosselect/demo/three/area.html

viewport缩放时处理方案

http://zhoushengfe.com/iosselect/demo/rem/bank.html

转载于:https://www.cnblogs.com/mufc-go/p/5446842.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Qt框架下模仿iOS语音波形图,可以使用Qt Multimedia模块和Qt Quick绘图功能来实现。 首先,我们需要使用Qt Multimedia模块录制音频,并获取音频的波形数据。通过QAudioInput类可以实现音频录制,并使用QAudioFormat设置音频格式。在录制过程中,可以通过QBuffer类收集音频数据,并使用QAudioBuffer将音频数据转换为波形数据。 接下来,我们可以将获取的波形数据显示在Qt Quick界面上的图形组件中。可以创建一个自定义的波形图形组件,继承自QQuickPaintedItem,并实现paint方法来绘制波形图形。在paint方法中,根据波形数据使用QPainter进行绘制,并根据音频的时间轴来确定波形的位置和形状。可以使用不同的颜色和样式来显示波形,以逼真地模仿iOS的语音波形图。 除了绘制波形图形,我们还可以为波形图形组件添加一些交互功能,例如拖动、缩放等。可以通过重写鼠标事件和触摸事件来实现这些功能,例如根据鼠标或手指的位置来确定当前选择的波形片段,并提供相应的操作。 最后,我们将自定义的波形图形组件嵌入到Qt Quick的界面中,通过QML语言进行布局和样式的调整。可以根据需要添加其他的界面元素,例如播放按钮、录制按钮等。 通过以上步骤,我们可以在Qt中实现一个模仿iOS语音波形图的界面。这样可以让用户在Qt应用程序中更加直观和便捷地查看和编辑音频波形数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值