-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathTiFadingScrollableView.js
108 lines (92 loc) · 2.76 KB
/
TiFadingScrollableView.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
/**
*
* @param args
* {
* parent = The parent view to which the scrollableView hast been added to
* views = array of views
* }
* @returns Ti.UI.ScrollableView
*/
exports.createScrollableView = function (args) {
/**
* Check completeness of args
*/
if (!args.views) {
return Ti.UI.createScrollableView(args);
}
if (!args.parent) {
return Ti.UI.createScrollableView(args);
}
var allViews = [];
/**
* create container for views
*/
for (var i = 0; i < args.views.length; i++) {
var item = args.views[i];
var scrollContainer = Ti.UI.createView({
backgroundColor: 'transparent',
width: args.width || Ti.UI.FILL,
height: args.height || Ti.UI.FILL
});
var backgroundImage = Ti.UI.createImageView({
opacity: (i == 0) ? 1 : 0,
image: item.backgroundImage,
width: args.width || Ti.UI.FILL,
height: args.height || Ti.UI.FILL
});
args.parent.add(backgroundImage);
scrollContainer.background = backgroundImage;
item.backgroundColor = 'transparent';
item.backgroundImage = null;
allViews.push(scrollContainer);
}
var scrollableView = Ti.UI.createScrollableView(args);
var currentPage = 0;
scrollableView.addEventListener('scroll', function (e) {
var right = e.currentPageAsFloat < parseFloat(currentPage);
var left = e.currentPageAsFloat > parseFloat(currentPage);
var opacity = e.currentPageAsFloat - currentPage;
if (opacity < 0) {
opacity = opacity * (-1);
}
if (left) {
/**
* Check if max entries is reached
*/
if (currentPage == allViews.length - 1) {
return;
}
var nextView = allViews[currentPage + 1];
if (nextView) {
nextView.background.opacity = opacity;
}
}
if (right) {
if (currentPage == 0) {
return;
}
opacity = 1 - opacity;
allViews[currentPage].background.opacity = opacity;
}
});
/**
* Make visible/invisible
* Set currentPage
*/
scrollableView.addEventListener('scrollend', function (e) {
currentPage = e.currentPage;
var prevView = allViews[currentPage - 1];
if (prevView) {
prevView.background.opacity = 1;
}
var actView = allViews[currentPage];
if (actView) {
actView.background.opacity = 1;
}
var nextView = allViews[currentPage + 1];
if (nextView) {
nextView.background.opacity = 0;
}
});
return scrollableView;
}