Compare commits

..

1 Commits

View File

@ -24,7 +24,7 @@ Item {
} }
QtObject{ QtObject{
id:d id:d
property bool flagXChanged: false property bool flagXChanged: true
property bool isAnimEnable: control.autoPlay && list_view.count>3 property bool isAnimEnable: control.autoPlay && list_view.count>3
function setData(data){ function setData(data){
if(!data){ if(!data){
@ -88,17 +88,14 @@ Item {
} }
} }
onMovementEnded:{ onMovementEnded:{
d.flagXChanged = false
list_view.highlightMoveDuration = 0
currentIndex = list_view.contentX/list_view.width currentIndex = list_view.contentX/list_view.width
if(currentIndex === 0){ if(currentIndex === 0){
currentIndex = list_view.count-2 currentIndex = list_view.count-2
}else if(currentIndex === list_view.count-1){ }else if(currentIndex === list_view.count-1){
currentIndex = 1 currentIndex = 1
} }
if(d.isAnimEnable){ d.flagXChanged = false
timer_run.restart() timer_run.restart()
}
} }
onMovementStarted: { onMovementStarted: {
d.flagXChanged = true d.flagXChanged = true
@ -107,12 +104,12 @@ Item {
onContentXChanged: { onContentXChanged: {
if(d.flagXChanged){ if(d.flagXChanged){
var maxX = Math.min(list_view.width*(currentIndex+1),list_view.count*list_view.width) var maxX = Math.min(list_view.width*(currentIndex+1),list_view.count*list_view.width)
var minX = Math.max(0,(list_view.width*(currentIndex-1))) var minY = Math.max(0,(list_view.width*(currentIndex-1)))
if(contentX>=maxX){ if(contentX>=maxX){
contentX = maxX contentX = maxX
} }
if(contentX<=minX){ if(contentX<=minY){
contentX = minX contentX = minY
} }
} }
} }