qml 实现 左右滑动切换页



  • qml 实现 左右滑动切换页 用哪个控件?



  • @Zero QML实现左右滑动切换页的控件,需要采用Qt的动画框架。比如说,在Qt的例子views的ObjectModel中,使用了ObjectModel配合了ListView进行绘制。这里是具体的代码,可以参考一下。

    /****************************************************************************
    **
    ** Copyright (C) 2015 The Qt Company Ltd.
    ** Contact: http://www.qt.io/licensing/
    **
    ** This file is part of the examples of the Qt Toolkit.
    **
    ** $QT_BEGIN_LICENSE:BSD$
    ** You may use this file under the terms of the BSD license as follows:
    **
    ** "Redistribution and use in source and binary forms, with or without
    ** modification, are permitted provided that the following conditions are
    ** met:
    **   * Redistributions of source code must retain the above copyright
    **     notice, this list of conditions and the following disclaimer.
    **   * Redistributions in binary form must reproduce the above copyright
    **     notice, this list of conditions and the following disclaimer in
    **     the documentation and/or other materials provided with the
    **     distribution.
    **   * Neither the name of The Qt Company Ltd nor the names of its
    **     contributors may be used to endorse or promote products derived
    **     from this software without specific prior written permission.
    **
    **
    ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
    ** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
    ** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
    ** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
    ** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
    ** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
    ** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
    ** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
    ** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
    ** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
    ** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
    **
    ** $QT_END_LICENSE$
    **
    ****************************************************************************/
    
    // This example demonstrates placing items in a view using
    // an ObjectModel
    
    import QtQuick 2.0
    import QtQml.Models 2.1
    
    Rectangle {
        id: root
        color: "lightgray"
        width: 320
        height: 480
        property bool printDestruction: false
    
    //! [0]
        ObjectModel {
            id: itemModel
    
            Rectangle {
                width: view.width; height: view.height
                color: "#FFFEF0"
                Text { text: "Page 1"; font.bold: true; anchors.centerIn: parent }
    
                Component.onDestruction: if (printDestruction) print("destroyed 1")
            }
            Rectangle {
                width: view.width; height: view.height
                color: "#F0FFF7"
                Text { text: "Page 2"; font.bold: true; anchors.centerIn: parent }
    
                Component.onDestruction: if (printDestruction) print("destroyed 2")
            }
            Rectangle {
                width: view.width; height: view.height
                color: "#F4F0FF"
                Text { text: "Page 3"; font.bold: true; anchors.centerIn: parent }
    
                Component.onDestruction: if (printDestruction) print("destroyed 3")
            }
        }
    
        ListView {
            id: view
            anchors { fill: parent; bottomMargin: 30 }
            model: itemModel
            preferredHighlightBegin: 0; preferredHighlightEnd: 0
            highlightRangeMode: ListView.StrictlyEnforceRange
            orientation: ListView.Horizontal
            snapMode: ListView.SnapOneItem; flickDeceleration: 2000
            cacheBuffer: 200
        }
    //! [0]
        Rectangle {
            width: root.width; height: 30
            anchors { top: view.bottom; bottom: parent.bottom }
            color: "gray"
    
            Row {
                anchors.centerIn: parent
                spacing: 20
    
                Repeater {
                    model: itemModel.count
    
                    Rectangle {
                        width: 5; height: 5
                        radius: 3
                        color: view.currentIndex == index ? "blue" : "white"
    
                        MouseArea {
                            width: 20; height: 20
                            anchors.centerIn: parent
                            onClicked: view.currentIndex = index
                        }
                    }
                }
            }
        }
    }
    
    


  • 我想在主界面上放多个标签页,他们采用滑动切换的方式换页,在每个标签页再上在放一个下拉刷新控件,要想实现这两个功能(滑动切换,下拉刷新)都需要ListView 控件,感觉嵌套的太多了



  • @Zero 说:

    方式换页
    嵌套得不算太多,我感觉在现有移动应用上还是能够接受的。



  • @Zero
    ListView 中有个属性是interactive



  • @qyvlik 一旦使用interactive: false,那么意味着就不能滑动ListView了。



  • @jiangcaiyang
    所以在嵌套的ListView中,这个就是主角了。



  • @jiangcaiyang @qyvlik
    现在遇到了新的问题

    ListView {
    id: pageView // 实现左右滑动换页功能
    delegate: PageViewDelegate {
    ListView {
    id: view // 实现下拉刷新功能
    delegate: ..略.
    model: ...略
    }
    }
    model: ListModel {
    id: listModel
    ListElement {
    cityName: "哈尔滨"
    }
    ListElement {
    cityName: "北京"
    }
    }

    感觉写的有点怪怪的,在最外层想访问view( 实现下拉刷新List)里的元素很困难,我应该怎样写pageView 的 model和delegate才能更好一点?
    再问一个问题,这个论坛怎么插入C++代码?



  • @Zero 首先是第二个问题:
    1、本论坛支持MarkDown语法,所以代码的引用,可以使用三个`(```)来引用之。比如说这样:

    This is a code snippet
    


  • @jiangcaiyang 第一个问题,我也觉得有点儿怪怪的。嵌套的ListView感觉不好。
    要么你使用ObjectModel,这里面的默认属性:children可以接收任何Item的子类实例。就像我在一楼中所展示的代码一样。
    所以说,ListView的model是ObjectModel,而ObjectModel里面再放入一个或者多个ListView即可。



  • ListView {
        id: pageView // 实现左右滑动换页功能
        delegate: PageViewDelegate {
            ListView {
                id: view // 实现下拉刷新功能
                delegate: ..略.
                model: ...略
            }
        }
        model: ListModel {
            id: listModel
            ListElement {
                cityName: "哈尔滨"
            }
            ListElement {
                cityName: "北京"
            }
    }


  • @jiangcaiyang
    遇到了一个悲催的问题 ObjectModel不支持动态添加节点吧?append函数要等到Qt 5.6才支持



  • @Zero 要动态的节点?那,还是尝试一下使用ListView吧。这样我感觉其实也不难的。这里需要注意的是,delegate的设置要准确。



  • 升级到了Qt 5.6beta,ObjectModel终于支持动态添加和删除节点了,但是ObjectModel的附加属性index如何使用,在ObjectModel的item中怎么调用不了index呢?有谁用过吗?指点一下


 

最近的回复

  • 0_1531879249244_9090909.jpg
    各位上午好哦。很高兴告诉大家,我们的萌梦社区又进行了一波更新了!
    这次主要更新在论坛代码层面上的,也就是说我们根据NodeBB官方的指示,将论坛从1.9.3升级到了1.10.1了!整个升级过程会产生一些服务暂停的现象,不过没有关系,很快就可以得到恢复,现在咱们可以顺利地在新的论坛上玩耍了!
    这次更新按照NodeBB官方的说法,主要在论坛的稳定性和迎合欧盟的GPDR政策(隐私权保护政策)上,也就是说,咱们论坛默认是支持用户的隐私权保护的~不要担心自己的隐私会被黑客利用什么的,但是大家还是要保护好平时论坛登录的密码哦。合适的时候还是使用浏览器的记住密码功能~

    此外,之前萌梦论坛之前的SSL加密是免费的,费时效果又不好。在手机浏览器上显示并非可靠的颁发者,现在换了新的证书,感觉好了不少。现在又可以在论坛上玩耍啦。

    好了,就是这样~

    阅读更多
  • @jiangcaiyang 是不支持QVector3D类型么,需要引用头文件还是需要转换类型呢

    阅读更多
  • 可能是Qt制作的Python绑定Shiboken遇到了问题。求先行者能够解忧~😵

    阅读更多
  • 0_1531804634749_5.jpg
    我使用的是PyCharm作为IDE,下载了Qt for Python(使用Qt 5.11),并且使用git克隆了pyside的源代码 + 例子。因为自己对OpenGL感兴趣,所以随手运行了一个例子。首先是PyOpenGL没有安装。

    0_1531804316021_1f365ea0-46b3-460d-9a00-c8cdeccf98af-image.png

    通过对话框弹出的命令,在terminal上运行

    python -m pip install PyOpenGL PyOpenGL_accelerate

    就可以了。

    虽然窗体以及3D内容出来了,但是命令提示符中会出现一些问题:

    D:/QtProject/pyside-setup/examples/opengl/hellogl2.py:394: RuntimeWarning: SbkConverter: Unimplemented C++ array type. self.program.setUniformValue(self.lightPosLoc, QVector3D(0, 0, 70)) D:/QtProject/pyside-setup/examples/opengl/hellogl2.py:423: RuntimeWarning: SbkConverter: Unimplemented C++ array type. self.program.setUniformValue(self.projMatrixLoc, self.proj) D:/QtProject/pyside-setup/examples/opengl/hellogl2.py:424: RuntimeWarning: SbkConverter: Unimplemented C++ array type. self.program.setUniformValue(self.mvMatrixLoc, self.camera * self.world) D:/QtProject/pyside-setup/examples/opengl/hellogl2.py:426: RuntimeWarning: SbkConverter: Unimplemented C++ array type. self.program.setUniformValue(self.normalMatrixLoc, normalMatrix)

    刚学习Python,还不清楚是怎么回事,怎么解决才好。

    阅读更多

关注我们

微博
QQ群











召唤伊斯特瓦尔