【功能】

/目录、文件
/文件过滤
/递归
/事件
/高亮当前行
/当前选项
/目录切换动画
/限制根目录

【下载】:http://download.csdn.net/detail/surfsky/8311503

【核心代码】

 import QtQuick 2.0
import Qt.labs.folderlistmodel 2.1 /**
QML目录导航列表
/目录文件
/文件过滤
/递归
/事件
/高亮当前行
/当前选项
/目录切换动画
/限制根目录 usage:
FolderListView{
onItemClicked:{
console.debug(JSON.stringify(item));
}
} author:
surfsky.cnblogs.com
2014-11
*/
ListView {
id: lv
width: 300
height: 600 //-----------------------------------------
// public
//-----------------------------------------
property int rowHeight: 30 // 行高
property int fontSize: 20 // 字体大小
property color hightlightColor: "#d0d0d0" // 高亮行背景色
property var fileFilter : ["*.qml"] // 文件过滤器
property string initFolder: './' // 初始目录
property string rootFolder : '../' // 限制根目录,不可再往上查找 // 点击事件(包括文件和目录)
signal itemClicked(var item); //-----------------------------------------
// 模型
//-----------------------------------------
model: folderModel
FolderListModel {
id: folderModel
nameFilters: lv.fileFilter
folder: lv.initFolder
showDirsFirst: true
showDotAndDotDot: true
} //-----------------------------------------
// 场景切换动画
//-----------------------------------------
PropertyAnimation on x{id: aniForward; from: lv.width; to: 0}
PropertyAnimation on x{id: aniBack; from: -lv.width; to: 0} //-----------------------------------------
// 高亮行
//-----------------------------------------
highlightFollowsCurrentItem: false
highlight: Rectangle {
width: lv.width;
height: lv.rowHeight
color: hightlightColor
y: lv.currentItem.y;
Behavior on y { PropertyAnimation { properties: 'y'; duration: 300; easing.type: Easing.OutExpo } }
//Behavior on y { SpringAnimation { spring: 2; damping: 0.1; duration:100 } }
} //-----------------------------------------
// 代理
//-----------------------------------------
delegate: Item{
width: parent.width
height: lv.rowHeight
Text {
text: fileName
anchors.verticalCenter: parent.verticalCenter
anchors.leftMargin: 10
font.pixelSize: lv.fontSize
x: 5
}
Text {
text: ">";
visible:fileIsDir;
anchors.verticalCenter: parent.verticalCenter
anchors.right: parent.right;
anchors.rightMargin: 10
font.pixelSize: lv.fontSize
}
Rectangle{
width: parent.width
height:1
color: '#f0f0f0'
y: parent.height - 1
x: 0
} MouseArea{
anchors.fill: parent
onClicked: {
parent.ListView.view.currentIndex = index // 触发节点点击事件
var json = {
isDir: fileIsDir,
name: fileName,
path: filePath,
url: fileURL.toString(),
baseName: fileBaseName,
suffix: fileSuffix,
size: fileSize,
modified: fileModified,
accessed: fileAccessed,
folderUrl: getFolder(fileURL.toString())
};
console.debug(JSON.stringify(json));
lv.itemClicked(json); // 目录处理
if (fileIsDir){
// 限制根目录
if (lv.rootFolder != ''){
var folderURL = (fileURL + '/').toLowerCase();
var rootFolderURL = Qt.resolvedUrl(lv.rootFolder).toLowerCase();
if (rootFolderURL.indexOf(folderURL) != -1){
console.log('limit root: ' + rootFolderURL);
return;
}
}
changeFolder(json.name, json.url);
}
} // 获取文件所在的目录
function getFolder(filePath)
{
var n = filePath.lastIndexOf('/');
var folder = filePath.substr(0, n+1);
return folder;
} // 更改目录(修改model并启动相应的动画)
function changeFolder(folderName, folderURL){
//folderModel.showDotAndDotDot = folderURL!=rootFolderURL; // (无效)
folderModel.folder = folderURL;
if (folderName == '..') aniBack.start();
else if (folderName == '.') ;
else aniForward.start();
}
}
} }

QT QML目录导航列表视图的更多相关文章

  1. Qt qml listview 列表视图控件(下拉刷新、上拉分页、滚动轴)

    Qt qml listview下拉刷新和上拉分页主要根据contentY来判断.但要加上顶部下拉指示器.滚动条,并封装成可简单调用的组件,着实花了我不少精力:) [先看效果]    [功能] 下拉刷新 ...

  2. Qt 学习之路 :视图代理

    与 Qt model/view 架构类似,在自定义用户界面中,代理扮演着重要的角色.模型中的每一个数据项都要通过一个代理向用户展示,事实上,用户看到的可视部分就是代理. 每一个代理都可以访问一系列属性 ...

  3. qml基础学习 模型视图(一)

    一.理解qml模型和视图 qt的发展是迅速的,虽然在每一个release版本中或多或少都有bug,但是作为一个庞大的gui库,no,应该说是一个开发框架开说,qt已经算是做的相当好.qml部分是qt4 ...

  4. 跟我学ASP.NET MVC之六:SportsStrore添加产品目录导航

    摘要: 上一篇文章,我建立了SportsStore应用程序的核心架构.现在我将使用这个架构向这个应用程序添加功能,你将开始看到这个基础架构的作用.我将添加重要的面向客户的简单功能,在这个过程中,你将看 ...

  5. 列表视图QlistView

    列表视图QlistView要配合setModel模型一起使用 例子一 QStringListModel()  字符串列表模型 import sys from PyQt5.QtWidgets impor ...

  6. JavaScript自动生成博文目录导航

    转载于:JavaScript自动生成博文目录导航 我们在写博客的时候,如果博文里面有目录,会给人结构清晰.一种一目了然的感觉,看目录就知道这篇博文要讲解的内容,并且点击目录标题就可以跳转到 具体的内容 ...

  7. Sharepoint 2013列表视图和字段权限扩展插件(免费下载)!

    记得2014年春节期间,有博客园的网友通过QQ向我咨询Sharepoint 2013列表视图和字段权限扩展,因为之前他看到我博客介绍Sharepoint 2010列表视图和字段的权限控制扩展使用,问有 ...

  8. Android——列表视图(ListView)

    列表视图是android中最常用的一种视图组件,它以垂直列表的形式列出需要显示的列表项.在android中有两种方法向屏幕中添加列表视图:一种是直接使用ListView组件创建:另外一种是让Activ ...

  9. Qt 学习之路:视图选择 (QItemSelectionModel)

    选择是视图中常用的一个操作.在列表.树或者表格中,通过鼠标点击可以选中某一项,被选中项会变成高亮或者反色.在 Qt 中,选择也是使用了一种模型.在 model/view 架构中,这种选择模型提供了一种 ...

随机推荐

  1. SQL日期相关的操作

    DECLARE @dt datetime SET @dt=GETDATE() DECLARE @number int --1.指定日期该年的第一天或最后一天 --A. 年的第一天 ),)+'1-1' ...

  2. Win7 IIS下启用ASP.NET

    问题产生的原因 先装的Win7,未启用IIS, 后启用IIS功能,即使选中开发选项只能默认打开ASP.net 中FrameWork2的支持,其它 版本的FrameWork默认IIS不支持,需要手工开启 ...

  3. IOS网络第四天 -网络文件上传(0923略)

    01-NSURLSession02-断点续传 02-文件上传01-基本的上传 03-文件上传03-代码封装 04-文件上传04-获得MIMEType.mp4 05-文件的压缩和解压缩.mp4 06-压 ...

  4. BZOJ 1003 物流运输【最短路】【动态规划】

    这道题数据太小啦!先枚举i,j表示从第i天到第j天不更改航线的费用. 然后直接跑最短路算法(我用的是Q版男朋友算法) 动归方程显然是f[i] = min(f[i], f[j] + cost[j+1][ ...

  5. 带你玩转JavaWeb开发之三 -JS插件实战开发

    前提:需要掌握的知识点           填写HTML代码 Element元素中有一个innerHTML属性,这个属性可以填写一段html代码 innerHTML = "<font ...

  6. js获取上传文件个数 以及名称

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. C/C++语言,自学资源,滚动更新中……

    首先要说<一本通>是一个很好的学习C/C++语言的自学教材. 以下教学视频中,缺少对"字符串"技术的讨论,大家注意看书.         一维数组,及其举例:(第四版) ...

  8. WordPress基础:Gravatar头像修正

    WordPress会根据你的邮箱,从Gravatar获取你的头像,如果没有在Gravatar设置头像,将使用默认的,然而设置了之后显示还可能会出现以下问题: Gravatar头像读取困难,将影响网站读 ...

  9. ios上position:fixed失效问题

    手机端上的猫腻真是多啊~~~ 此起彼伏! 最近又遇到了 固定定位的底部导航在ios上被弹出去 此时内心1w+个草泥马奔过~~~~~~~~ 直接上解决方案: <div class="ma ...

  10. [Android Tips] 19. Android Studio Plugins

    Code Generation GsonFormat json 字符串生成实体类 https://github.com/zzz40500/GsonFormat Android Parcelable C ...