qml: 另类图像轮播;
一般来说,图像轮播都是采用ListView等model进行设计, 比较方便。 这里展示我自己设计的图像轮播
方案, 仅采用两个QImage实现;
下面展示代码以及简述:(注: 以下代码为本人原创, 如需要应用于商业,请留言通知!)
import QtQuick 2.0
import QtQuick.Window 2.3
import QtQuick.Controls 1.4
import MaterialUI 1.0
import com.Advertisement 1.0
AppWindow{
id: adverpage;
flags:Qt.FramelessWindowHint;
bDomal: true;
x: (Screen.desktopAvailableWidth - width)/2;
y: (Screen.desktopAvailableHeight - height)/2; QtObject{
id:__inter;
property var advertises: adver.avertises;
property real index: -1;
property real time: 20; //广告时间; //找到下一个;
property var firstImg : img1.x == 0? img2: img1;
property var secondImg : img1.x == 0 ?img1: img2;
property var firstMove : img1.x == 0? img2Moving: img1Moving;
property var secondMove : img1.x == 0? img1Moving: img2Moving;
property var nextIndex: index+1 >= advertises.length ? 0: index + 1; //得到下一个序号;
} function play()
{
//初始化;
__inter.index++;
if( __inter.advertises.length >= 2)
{
if( Qt.platform.os == "windows")
{
img1.source = "file:///" + __inter.advertises[__inter.index];
img2.source = "file:///" + __inter.advertises[__inter.nextIndex];
}else{
img1.firstImg.source = __inter.advertises[__inter.index];
img2.source = __inter.advertises[__inter.nextIndex];
}
}
remainTime.text = __inter.time.toString() + " 秒";
timer.start();
} function stop()
{
timer.stop();
adverpage.close();
} function scroll()
{
__inter.time--; //时间更新;
remainTime.text = __inter.time.toString() + " 秒";
if( __inter.time > 0 )
{
console.log(__inter.advertises[__inter.index]);
if( Qt.platform.os == "windows")
{
__inter.secondImg.source = "file:///" + __inter.advertises[__inter.nextIndex]; //预存图像;
}else{
__inter.secondImg.source = __inter.advertises[__inter.nextIndex];
}
__inter.firstMove.from = 0;
__inter.firstMove.to = -__inter.firstImg.width;
__inter.secondMove.from = __inter.secondImg.width;
__inter.secondMove.to = 0;
__inter.firstMove.start();
__inter.secondMove.start();
}else{
timer.stop();
adverpage.close();
}
__inter.index = __inter.nextIndex; //下一个;
}
Rectangle{
id: scrollArea;
width: img1.x > img2.x? img1.width: img2.width;
height:Math.max(img1.height, img2.height);
clip: true;
Row{
spacing: Global.margin;
z: 2;
anchors{
top: parent.top;
topMargin: Global.margin;
right: parent.right;
rightMargin: Global.margin;
}
Label{ //倒计时以及“关闭广告”功能;
id: remainTime;
width: 50;
height: 20;
color: "red";
font.bold: true;
horizontalAlignment: Text.AlignRight
verticalAlignment: Text.AlignVCenter
}
Label{
width: 50;
height: 20;
color: "red";
font.bold: true;
horizontalAlignment: Text.AlignHCenter
verticalAlignment: Text.AlignVCenter
text:qsTr("关闭广告");
MouseArea{
anchors.fill: parent;
onClicked:{
console.log("no right to close");
stop();
}
}
}
} Image {
id:img1
cache: false;
x: 0;
anchors.verticalCenter: parent.verticalCenter;
NumberAnimation{
id: img1Moving;
target: img1
properties: "x"
duration: 300;
}
}
Image{
id: img2;
cache: false;
x: img1.width;
anchors.verticalCenter: parent.verticalCenter;
NumberAnimation{
id: img2Moving;
target: img2
properties: "x"
duration: 300;
}
} MouseArea{ //暂停功能;
anchors.fill: parent;
cursorShape: Qt.PointingHandCursor
onClicked: {
if( timer.running )
timer.stop();
else
timer.restart();
}
}
} Advertisement{ //从本地获取要展示的广告列表;
id: adver;
} Timer{ //定时器,用于轮播;
id: timer;
repeat: true;
interval: 1500;
onTriggered:{
scroll();
}
}
}
qml: 另类图像轮播;的更多相关文章
- jquery的fadeTo方法的淡入淡出轮播图插件
由于对基于jquery的简单插件开发有了一定的了解,慢慢的也对基于jquery的插件开发有了兴趣,在上班结束之后就研究各种插件的思路逻辑.最近开发了一款基于jquery的fadeTo方法的轮播图插件, ...
- Qt编写自定义控件23-广告轮播控件
一.前言 广告轮播这个控件做的比较早,是很早以前定制一个电信客户端时候用到的,该客户端需要在首页展示轮播预先设定好的图片,图片的路径可以自由设定,然后轮播的间隔速度可以自由控制,同时该控件还需要提供两 ...
- CSS3常用属性(边框、背景、文本效果、2D转换、3D转换、过渡、有过渡效果大图轮播、动画)
CSS3边框: 1.CSS3圆角:border-radius 属性--创建边框线的圆角 <body style="font-size:24px; color:#60F;"& ...
- Jquery 轮播图简易框架
=====================基本结构===================== <div class="carousel" style="width: ...
- 12款经典的白富美型—jquery图片轮播插件—前端开发必备
图片轮播是网站中的常用功能,用于在有限的网页空间内展示一组产品图片或者照片,同时还有非常吸引人的动画效果.本文向大家推荐12款实用的 jQuery 图片轮播效果插件,帮助你在你的项目中加入一些效果精美 ...
- 第十篇.bootstrap轮播
使用bootstrap的轮播插件可以向站点添加滑块,内容可以是图像,内嵌框架,视频或其它任何内容,使用轮播插件需要引入bootstrap.min.js. <div id="carous ...
- html+css+javascript实现简易轮播图片
html: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <lin ...
- Nivo Slider - 世界上最棒的 jQuery 图片轮播插件
Nivo Slider 号称世界上最棒的图片轮播插件,有独立的 jQuery 插件和 WordPress 插件两个版本.目前下载量已经突破 1,800,000 次!jQuery 独立版本的插件主要有如 ...
- Android学习笔记之图片轮播...
PS:一个bug又折腾了一个下午....哎... 学习内容: 1.Android利用ViewPager和PagerAdapter实现图片轮播... 2.使用反射机制获取Android的资源信息... ...
随机推荐
- 树&图 记录
A - Lake Counting POJ - 2386 最最最最最基础的dfs 挂这道题为了提高AC率(糖水不等式 B - Paint it really, really dark gray Cod ...
- UVA 12171 Sculpture
https://vjudge.net/problem/UVA-12171 题目 某人设计雕塑,用的是很扯的方法:把一堆长方体拼起来.给出长方体的坐标和长宽高,求外表面积.因为要将这雕塑进行酸洗,需要知 ...
- java Builder模式创建不可变类
package com.geostar.gfstack.operationcenter.logger.manager.common; /** * Created by Nihaorz on 2017/ ...
- [Codeforces1132G]Greedy Subsequences——线段树+单调栈
题目链接: Codeforces1132G 题目大意:给定一个序列$a$,定义它的最长贪心严格上升子序列为$b$满足若$a_{i}$在$b$中则$a_{i}$之后第一个比它大的也在$b$中.给出一个数 ...
- ajax 提交数组 泛型集合(嵌套集合)
直接上代码 后台接口: A类型中嵌套了 List<B> B类型中嵌套了 List<C> [HttpPost] public string Post(A a) { return ...
- Logger.error方法之打印错误异常的详细堆栈信息
一.问题场景 使用Logger.error方法时只能打印出异常类型,无法打印出详细的堆栈信息,使得定位问题变得困难和不方便. 二.先放出结论 Logger类下有多个不同的error方法,根据传入参数的 ...
- for循环是怎么工作的
for...in 是Python程序员使用最多的语句,for 循环用于迭代容器对象中的元素,这些对象可以是列表.元组.字典.集合.文件,甚至可以是自定义类或者函数,例如: 作用于列表 >> ...
- 【原创】tyvj1038 忠诚 & 计蒜客 管家的忠诚 & 线段树(单点更新,区间查询)
最简单的线段树之一,中文题目,不翻译.... 注释讲的比较少,这已经是最简单的线段树,如果看不懂真的说明最基础的理论没明白 推荐一篇文章http://www.cnblogs.com/liwenchi/ ...
- 20165223 week6测试错题总结
由于时间预估错误及手机自身卡顿问题,虽然已经作答完成,却在最后提交时出现错误,错失提交时间,所以没能按时提交答案,也就没有纠错,以下仅凭印象列出错题: Q1:若超出JVM运行能力,如"byt ...
- 牛客练习赛28 B数据结构(线段树)
链接:https://www.nowcoder.com/acm/contest/200/B来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言5242 ...