├── LICENSE
├── README.md
├── assets
├── arrow1.png
├── arrow2.png
├── blueBlock.png
├── box.png
├── cancel_paused.png
├── char1.png
├── char2.png
├── char3.png
├── char4.png
├── greenBlock.png
├── pinkBlock.png
├── purpleBlock.png
├── stripe.png
└── yellowBlock.png
├── examples
├── core.js
├── core_example1.js
├── example1.html
├── index.html
├── phase-slide.js
└── phaser.min.js
├── phase-slide.js
└── phase-slider.min.js
/LICENSE:
--------------------------------------------------------------------------------
1 | The MIT License (MIT)
2 |
3 | Copyright (c) 2015 Michael Dobekidis
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
23 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # PhaseSlider
2 | A slider UI component for Phaser.io Javascript library
3 |
4 |
Initialize the slider in your preload function
5 |
6 | ```
7 | slider = new phaseSlider(game); //make sure to have slider publicly available
8 | ```
9 |
10 | And then simply construct your slider in the main function of your game or anywhere else
11 |
12 | ```
13 | slider.createSlider({
14 | customSliderBG: false,
15 | mode: "horizontal",
16 | sliderBGAlpha: 0.8,
17 | width: 500,
18 | height: 400,
19 | x: game.width / 2 - 500 / 2,
20 | y: game.height / 2 - 400 / 2,
21 | objects:[block1, block2, block3, block4, block5]
22 | });
23 | ```
24 |
25 |
26 |
27 | >View examples:
28 | Advanced example |
29 | Simple example
30 |
31 |
32 |
33 | General Options:
34 |
35 |
36 | mode: Type of movement for the slides (default horizontal, vertical-from-bottom, vertical-from-top)
37 | width: The width of the slider (default 500 pixels)
38 | height: The height of the slider (default 400 pixels)
39 | x The x position of the slider (default 0)
40 | y The y position of the slider (default 0)
41 | objects An array of sprites or groups that will be the slides (added as they appear on the array left->right)
42 | animationDuration: This sets the speed of the animation while sliding (default: 600ms)
43 | animationEasing: The easing applied to the sliding animation (default Phaser.Easing.Cubic.Out)
44 | sliderBG A single color to paint the background of the slider (default #35d2e0)
45 | customSliderBG A cache value to serve as a background for the slider (default false)
46 | sliderBGAlpha The alpha value for the slider background (default 1)
47 | customHandleNext A cache value for the the right arrow (if omited the liv has a build-in image to place)
48 | customHandlePrev A cache value for the the left arrow (if omited the liv has a build-in image to place)
49 | showHandles Whether or not to show arrows for slider navigation (default true)
50 | onNextCallback A callback function to be called when the slider navigates forward (default false)
51 | onPrevCallback A callback function to be called when the slider navigates backwards (default false)
52 | autoAnimate If we want the slider to aumatically rotate the slider (default false)
53 | animationDelay The delay between slide change when autoAnimate is set to true (default 2s)
54 | modal Add a black modal behind the slider (default false)
55 | modalAlpha The amount of alpha (opacity) for the slider modal (default 0.7)
56 | staticElements The static elements that need to be added but not move (default [])
57 | onPrePrevCallback The function to call `before` the slider moves to the `previous` slide (default false)
58 | onPreNextCallback The function to call `before` the slider moves to the `next` slide (default false)
59 | onAfterPrevCallback The function to call `after` the slider moves to the `previous` slide (default false)
60 | onAfterNextCallback The function to call `after` the slider moves to the `next` slide (default false)
61 |
62 |
63 | API Functions
64 |
65 |
66 | createSlider | Creates the slider object and the slides
67 | startSlider | Starts the automatic rotation of the slider if autoAnimate is set to true
68 | stopSlider | Stops the automatic rotation of slides
69 | moveToSlide | Navigate to specific slide index (args: index:Number, animated:Boolean)
70 | goToNext | Navigate to the next slide
71 | goToPrev | Navigate to the previous slide
72 | getCurrentIndex | Receive the current slide index
73 | hideSlider | Render the slider not visible (the slider will not be able to receive input events)
74 | showSlider | Render the slider visible
75 |
76 |
77 |
78 | *Note: When automatic rotation has started, navigating from the control arrows (next, prev) will stop the auto animation
79 |
80 |
81 |
82 |
83 | >Please let me know if you come across some bug or have something to contribute
84 |
85 |
86 |
87 |
88 |
89 |
--------------------------------------------------------------------------------
/assets/arrow1.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/netgfx/PhaseSlider/bb86f00c77316da49f8387be0bd1a30c6cf421c6/assets/arrow1.png
--------------------------------------------------------------------------------
/assets/arrow2.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/netgfx/PhaseSlider/bb86f00c77316da49f8387be0bd1a30c6cf421c6/assets/arrow2.png
--------------------------------------------------------------------------------
/assets/blueBlock.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/netgfx/PhaseSlider/bb86f00c77316da49f8387be0bd1a30c6cf421c6/assets/blueBlock.png
--------------------------------------------------------------------------------
/assets/box.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/netgfx/PhaseSlider/bb86f00c77316da49f8387be0bd1a30c6cf421c6/assets/box.png
--------------------------------------------------------------------------------
/assets/cancel_paused.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/netgfx/PhaseSlider/bb86f00c77316da49f8387be0bd1a30c6cf421c6/assets/cancel_paused.png
--------------------------------------------------------------------------------
/assets/char1.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/netgfx/PhaseSlider/bb86f00c77316da49f8387be0bd1a30c6cf421c6/assets/char1.png
--------------------------------------------------------------------------------
/assets/char2.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/netgfx/PhaseSlider/bb86f00c77316da49f8387be0bd1a30c6cf421c6/assets/char2.png
--------------------------------------------------------------------------------
/assets/char3.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/netgfx/PhaseSlider/bb86f00c77316da49f8387be0bd1a30c6cf421c6/assets/char3.png
--------------------------------------------------------------------------------
/assets/char4.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/netgfx/PhaseSlider/bb86f00c77316da49f8387be0bd1a30c6cf421c6/assets/char4.png
--------------------------------------------------------------------------------
/assets/greenBlock.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/netgfx/PhaseSlider/bb86f00c77316da49f8387be0bd1a30c6cf421c6/assets/greenBlock.png
--------------------------------------------------------------------------------
/assets/pinkBlock.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/netgfx/PhaseSlider/bb86f00c77316da49f8387be0bd1a30c6cf421c6/assets/pinkBlock.png
--------------------------------------------------------------------------------
/assets/purpleBlock.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/netgfx/PhaseSlider/bb86f00c77316da49f8387be0bd1a30c6cf421c6/assets/purpleBlock.png
--------------------------------------------------------------------------------
/assets/stripe.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/netgfx/PhaseSlider/bb86f00c77316da49f8387be0bd1a30c6cf421c6/assets/stripe.png
--------------------------------------------------------------------------------
/assets/yellowBlock.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/netgfx/PhaseSlider/bb86f00c77316da49f8387be0bd1a30c6cf421c6/assets/yellowBlock.png
--------------------------------------------------------------------------------
/examples/core.js:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/netgfx/PhaseSlider/bb86f00c77316da49f8387be0bd1a30c6cf421c6/examples/core.js
--------------------------------------------------------------------------------
/examples/core_example1.js:
--------------------------------------------------------------------------------
1 | // Copyright © 2015 Michael Dobekidis
2 | // Licensed under the terms of the MIT License
3 | var reg = {};
4 | var GameState = function (game) {};
5 | var slider;
6 | // Load images and sounds
7 | GameState.prototype.preload = function () {
8 | this.load.image('bg', "http://i221.photobucket.com/albums/dd22/djmid71/bg1_zpsxrhh1f86.jpg");
9 | this.load.image("block1", "../assets/pinkBlock.png");
10 | this.load.image("block2", "../assets/blueBlock.png");
11 | this.load.image("block3", "../assets/greenBlock.png");
12 | this.load.image("block4", "../assets/yellowBlock.png");
13 | this.load.image("block5", "../assets/purpleBlock.png");
14 |
15 | this.load.image("arrow1", "../assets/arrow1.png");
16 | this.load.image("arrow2", "../assets/arrow2.png");
17 | this.load.image("accept", "../assets/stripe.png");
18 | this.load.image("box", "../assets/box.png");
19 | this.load.image("cancel", "../assets/cancel_paused.png");
20 | this.load.image("char1", "../assets/char1.png");
21 | this.load.image("char2", "../assets/char2.png");
22 | this.load.image("char3", "../assets/char3.png");
23 | this.load.image("char4", "../assets/char4.png");
24 | slider = new phaseSlider(game);
25 | };
26 |
27 | // Setup the example
28 | GameState.prototype.create = function () {
29 | // Set stage background to something sky colored
30 | this.game.stage.backgroundColor = 0xcdcdcd;
31 | this.add.image(0, 0, "bg");
32 | var char1 = game.add.image(0,0,"char1");
33 | var char2 = game.add.image(0,0,"char2");
34 | var char3 = game.add.image(0,0,"char3");
35 | var char4 = game.add.image(0,0,"char4");
36 |
37 | var group1 = game.add.group();
38 | group1.width = 500;
39 | group1.height = 400;
40 | char1.scale.setTo(0.5, 0.5);
41 | char1.x = 500/2 - char1.width/2;
42 | char1.y = 100;
43 |
44 | //////////
45 | var group2 = game.add.group();
46 | group2.width = 500;
47 | group2.height = 400;
48 | char2.scale.setTo(0.5, 0.5);
49 | char2.x = 500/2 - char2.width/2;
50 | char2.y = 100;
51 | ///////////
52 | var group3 = game.add.group();
53 | group3.width = 500;
54 | group3.height = 400;
55 | char3.scale.setTo(0.5, 0.5);
56 | char3.x = 500/2 - char3.width/2;
57 | char3.y = 100;
58 | ////////////
59 | var group4 = game.add.group();
60 | group4.width = 500;
61 | group4.height = 400;
62 | char4.scale.setTo(0.5, 0.5);
63 | char4.x = 500/2 - char4.width/2;
64 | char4.y = 100;
65 |
66 |
67 |
68 | var block1 = game.add.image(0,0,"block1");
69 | var block2 = game.add.image(0,0,"block1");
70 | var block3 = game.add.image(0,0,"block1");
71 | var block4 = game.add.image(0,0,"block1");
72 |
73 | group1.add(block1);
74 | group1.add(char1);
75 | /////
76 | group2.add(block2);
77 | group2.add(char2);
78 | /////
79 | group3.add(block3);
80 | group3.add(char3);
81 | /////
82 | group4.add(block4);
83 | group4.add(char4);
84 |
85 |
86 | slider.createSlider({
87 | customSliderBG: false,
88 | sliderBGAlpha: 0.8,
89 | x: game.width / 2 - 500 / 2,
90 | y: game.height / 2 - 400 / 2,
91 | customHandleNext: "arrow2",
92 | customHandlePrev: "arrow1",
93 | objects:[group1, group2, group3, group4],
94 | onNextCallback: function() {
95 | window.console.log("next");
96 | },
97 | onPrevCallback: function(){
98 | window.console.log("prev")
99 | }
100 | });
101 |
102 | var btn = game.add.image((game.width/2 - 80/2), (game.height / 2 - 80 / 2)+180, "accept");
103 | btn.inputEnabled = true;
104 | btn.events.onInputDown.add(function (e, pointer) {
105 | var index = slider.getCurrentIndex();
106 | var text = game.add.text(0,0,"You selected -> ",{
107 | fontSize: 22,
108 | fill: "#1e1e1e"
109 | });
110 | text.updateText();
111 |
112 | text.x = game.width/2 - text.width/2;
113 | text.y = 80;
114 |
115 | var img = game.add.image(text.x+text.width+10, text.y-30, "char"+(index+1));
116 | img.scale.setTo(0.2, 0.2);
117 |
118 | },this);
119 | };
120 |
121 |
122 |
123 | // The update() method is called every frame
124 | GameState.prototype.update = function () {
125 |
126 | };
127 |
128 | var game = new Phaser.Game(1024, 691, Phaser.CANVAS, 'game');
129 | game.state.add('game', GameState, true);
--------------------------------------------------------------------------------
/examples/example1.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 | CodePen - Phase-Slide
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
--------------------------------------------------------------------------------
/examples/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 | CodePen - Phase-Slide
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
--------------------------------------------------------------------------------
/examples/phase-slide.js:
--------------------------------------------------------------------------------
1 | /**
2 | * PHASE-SLIDE IS A UI SLIDER FOR PHASER.IO LIBRARY
3 | *
4 | * COPYWRITE-2015
5 | * AUTHOR: MICHAEL DOBEKIDIS (NETGFX.COM)
6 | *
7 | */
8 |
9 | var phaseSlider = phaseSlider || {};
10 |
11 |
12 | phaseSlider = function (game) {
13 |
14 | var _this = this;
15 |
16 | game.phaseSlider = _this;
17 | _this.game = game;
18 | _this.locked = false;
19 | _this.slideIndex = 0;
20 | _this.slider_timer = null;
21 | _this.tweenObj = {};
22 |
23 | var chevron_left = "";
24 |
25 | var chevron_right = "";
26 |
27 | game.load.image("slider_chevron_left", chevron_left);
28 | game.load.image("slider_chevron_right", chevron_right);
29 |
30 | _this.goToNext = function () {
31 | _this.locked = true;
32 | if (_this.options._mode === "horizontal") {
33 | var finalX = _this.sliderMainGroup.x + (_this.options._width * -1);
34 |
35 | if ((_this.slideIndex >= _this.options._objects.length - 1) && _this.options.autoAnimate === false) {
36 | _this.stopSlider();
37 | return false;
38 | }
39 |
40 | // animate loop
41 | if (_this.options.autoAnimate === true) {
42 | if (_this.slideIndex >= _this.options._objects.length - 1) {
43 | _this.slideIndex = 0;
44 | _this.sliderMainGroup.x = _this.options._x;
45 | this.locked = false;
46 | return true;
47 | }
48 | }
49 |
50 | _this.tweenObj = game.add.tween(_this.sliderMainGroup).to({
51 | x: finalX
52 | }, _this.options.animationDuration, _this.options.animationEasing, true, 0, 0, false);
53 | _this.tweenObj.onComplete.add(function () {
54 | this.locked = false;
55 | this.slideIndex += 1;
56 | if (_this.options.autoAnimate === false && this.slideIndex >= _this.options._objects.length - 1) {
57 | if (_this.options._showHandles === true) {
58 | this.sliderControlsGroup.children[0].alpha = 0;
59 | }
60 | }
61 |
62 | // enable prev
63 | if (_this.options._showHandles === true) {
64 | this.sliderControlsGroup.children[1].alpha = 1;
65 | }
66 | }, _this);
67 | } else {
68 |
69 | var finalY;
70 | if (_this.options._mode === "vertical-from-top") {
71 | finalY = _this.sliderMainGroup.y + (_this.options._height);
72 | } else if (_this.options._mode === "vertical-from-bottom") {
73 | finalY = _this.sliderMainGroup.y + (_this.options._height * -1);
74 | }
75 |
76 | if ((_this.slideIndex >= _this.options._objects.length - 1) && _this.options.autoAnimate === false) {
77 | _this.stopSlider();
78 | return false;
79 | }
80 |
81 | // animate loop
82 | if (_this.options.autoAnimate === true) {
83 | if (_this.slideIndex >= _this.options._objects.length - 1) {
84 | _this.slideIndex = 0;
85 | _this.sliderMainGroup.y = _this.options._y;
86 | this.locked = false;
87 | return true;
88 | }
89 | }
90 |
91 | _this.tweenObj = game.add.tween(_this.sliderMainGroup).to({
92 | y: finalY
93 | }, _this.options.animationDuration, _this.options.animationEasing, true, 0, 0, false);
94 | _this.tweenObj.onComplete.add(function () {
95 | this.locked = false;
96 | this.slideIndex += 1;
97 |
98 | if (_this.options.autoAnimate === false && this.slideIndex >= _this.options._objects.length - 1) {
99 | if (_this.options._showHandles === true) {
100 | this.sliderControlsGroup.children[0].alpha = 0;
101 | }
102 | }
103 |
104 | // enable prev
105 | if (_this.options._showHandles === true) {
106 | this.sliderControlsGroup.children[1].alpha = 1;
107 | }
108 | }, _this);
109 | }
110 | };
111 | _this.goToPrev = function () {
112 | _this.locked = true;
113 | if (_this.options._mode === "horizontal") {
114 | var finalX = _this.sliderMainGroup.x + (_this.options._width);
115 |
116 | if (_this.slideIndex <= 0 && _this.options.autoAnimate === false) {
117 | _this.stopSlider();
118 | return false;
119 | }
120 |
121 | _this.tweenObj = game.add.tween(_this.sliderMainGroup).to({
122 | x: finalX
123 | }, _this.options.animationDuration, _this.options.animationEasing, true, 0, 0, false);
124 | _this.tweenObj.onComplete.add(function () {
125 | this.locked = false;
126 | this.slideIndex -= 1;
127 |
128 | if (this.slideIndex < 0) {
129 | this.slideIndex = 0;
130 | }
131 |
132 | if (_this.options.infiniteLoop === false && this.slideIndex <= 0) {
133 | // enable prev
134 | if (_this.options._showHandles === true) {
135 | this.sliderControlsGroup.children[1].alpha = 0;
136 | }
137 | }
138 |
139 | // enable next
140 | if (_this.options._showHandles === true) {
141 | this.sliderControlsGroup.children[0].alpha = 1;
142 | }
143 |
144 | }, _this);
145 | } else {
146 | var finalY;
147 | if (_this.options._mode === "vertical-from-top") {
148 | finalY = _this.sliderMainGroup.y + (_this.options._height * -1);
149 | } else if (_this.options._mode === "vertical-from-bottom") {
150 | finalY = _this.sliderMainGroup.y + (_this.options._height);
151 | }
152 | if (_this.slideIndex <= 0 && _this.options.autoAnimate === false) {
153 | _this.stopSlider();
154 | return false;
155 | }
156 |
157 | _this.tweenObj = game.add.tween(_this.sliderMainGroup).to({
158 | y: finalY
159 | }, _this.options.animationDuration, _this.options.animationEasing, true, 0, 0, false);
160 | _this.tweenObj.onComplete.add(function () {
161 | this.locked = false;
162 | this.slideIndex -= 1;
163 |
164 | if (this.slideIndex < 0) {
165 | this.slideIndex = 0;
166 | }
167 |
168 | if (_this.options.autoAnimate === false && this.slideIndex <= 0) {
169 | if (_this.options._showHandles === true) {
170 | this.sliderControlsGroup.children[1].alpha = 0;
171 | }
172 | }
173 |
174 | // enable prev
175 | if (_this.options._showHandles === true) {
176 | this.sliderControlsGroup.children[0].alpha = 1;
177 | }
178 | }, _this);
179 | }
180 | };
181 |
182 | _this.startSlider = function () {
183 | var _timer = game.time.create(false);
184 | _timer.start();
185 | _timer.loop(Phaser.Timer.SECOND * _this.options.animationDelay, _this.goToNext, _this);
186 | _this.slider_timer = _timer;
187 | };
188 | _this.stopSlider = function () {
189 | if (_this.slider_timer !== null) {
190 | _this.slider_timer.stop(true);
191 | _this.slider_timer = null;
192 | } else {
193 | return false;
194 | }
195 | };
196 |
197 | _this.moveToSlide = function (index, animate) {
198 | var finalX;
199 | if (index >= _this.options._objects.length) {
200 | return false;
201 | }
202 | if (_this.options._mode === "horizontal") {
203 | finalX = (_this.options._x - (_this.options._width * (index)));
204 | if (animate === true) {
205 |
206 | var tweenObj = game.add.tween(_this.sliderMainGroup).to({
207 | x: finalX
208 | }, _this.options.animationDuration, _this.options.animationEasing, true, 0, 0, false);
209 | } else {
210 | _this.sliderMainGroup.x = finalX;
211 | }
212 | } else if (_this.options._mode === "vertical-from-top") {
213 | //TODO: ADD VERTICAL-FROM-TOP
214 | } else if (_this.options._mode === "vertical-from-bottom") {
215 | //TODO: ADD VERTICAL-FROM-BOTTOM
216 | }
217 | };
218 | /////////////////////////////////////////////////////////////////////////////////////////
219 | ///
220 | _this.onDragStart = function (sprite, pointer, dragX, dragY) {
221 | _this.dragInit = pointer.x;
222 | _this.lastDrag = pointer.x;
223 | };
224 |
225 | _this.onDragStop = function (e) {
226 |
227 | };
228 | _this.dragUpdate = function (sprite, pointer, dragX, dragY) {
229 |
230 | var finalX = dragX; // - _this.options._x;
231 | // going left
232 | if (pointer.x < _this.dragInit) {
233 | var diff = Math.abs(pointer.x) - Math.abs(_this.lastDrag);
234 | // going right
235 | if (diff < 0) {
236 | finalX = _this.sliderMainGroup.x - 1;
237 | } else {
238 | finalX = _this.sliderMainGroup.x + 1;
239 | }
240 | } else {
241 | var diff = Math.abs(pointer.x) - Math.abs(_this.lastDrag);
242 | // going right
243 | if (diff < 0) {
244 | finalX = _this.sliderMainGroup.x - 1;
245 | } else {
246 | finalX = _this.sliderMainGroup.x + 1;
247 | }
248 | }
249 |
250 | if (finalX <= (_this.options._x + (_this.options._width * (_this.options._objects.length - 2))) * -1) {
251 | finalX = (_this.options._x + (_this.options._width * (_this.options._objects.length - 2))) * -1;
252 | } else if (finalX >= _this.options._x) {
253 | finalX = _this.options._x;
254 | }
255 | _this.sliderMainGroup.x = finalX;
256 | _this.lastDrag = pointer.x;
257 | };
258 |
259 | return {
260 | createSlider: function (options) {
261 | // initialize index
262 | _this.slideIndex = 0;
263 |
264 | _this.options = {
265 | _mode: options.mode || "horizontal", // horizontal, vertical-from-top, vertical-from-bottom
266 | _width: options.width || 500,
267 | _height: options.height || 400,
268 | _animationEffect: options.animationEffect || "slide", // slide, fade, cover
269 | autoAnimate: options.autoAnimate || false,
270 | infiniteLoop: options.infiniteLoop || false,
271 | animationDelay: options.animationDelay || 2,
272 | animationDuration: options.animationDuration || 600,
273 | animationEasing: options.animationEasing || Phaser.Easing.Cubic.Out, //Phaser.Easing.Linear.None,
274 | _x: options.x || 0,
275 | _y: options.y || 0,
276 | _objects: options.objects || [], // can take: single-sprite, single-image, group
277 | sliderBG: options.sliderBG || 0x35d2e0,
278 | customSliderBG: options.customSliderBG || false,
279 | sliderBGAlpha: options.sliderBGAlpha || 1,
280 | _customHandleNext: options.customHandleNext || "",
281 | _customHandlePrev: options.customHandlePrev || "",
282 | _showHandles: options.showHandles == undefined ? true : options.showHandles,
283 | _onNextCallback: options.onNextCallback || false,
284 | _onPrevCallback: options.onPrevCallback || false,
285 | _addModal: options.modal || false,
286 | _modalAlpha: options.modalAlpha || 0.7,
287 | _staticElements: options.staticElements || []
288 | };
289 |
290 | //////////////////////////////////////////////////////////////////////////////////////////////
291 |
292 | var bgRect;
293 | _this._modal = {};
294 | if(_this.options._addModal === true) {
295 | _this._modal = game.add.graphics(game.width, game.height);
296 | _this._modal.beginFill(0x000000, _this.options._modalAlpha);
297 | _this._modal.x = 0;
298 | _this._modal.y = 0;
299 | _this._modal.inputEnabled = true;
300 | _this._modal.drawRect(0, 0, _this.game.width, _this.game.height);
301 | }
302 | else {
303 | _this._modal = false;
304 | }
305 |
306 | //////// OBJECTS GROUP
307 | ///
308 | _this.sliderBGGroup = _this.game.add.group();
309 | _this.sliderMainGroup = _this.game.add.group();
310 | _this.sliderBGGroup.width = _this.options._width;
311 | _this.sliderMainGroup.width = _this.options._width;
312 | if (_this.options._mode === "horizontal") {
313 | _this.sliderMainGroup.width = _this.options._width * _this.options._objects.length;
314 |
315 | // if used as a placeholder don't make the width = 0
316 | if (_this.options._objects.length === 0) {
317 | _this.sliderMainGroup.width = _this.options._width;
318 | }
319 | } else {
320 | _this.sliderMainGroup.height = _this.options._height * _this.options._objects.length;
321 |
322 | // if used as a placeholder don't make the height = 0
323 | if (_this.options._objects.length === 0) {
324 | _this.sliderMainGroup.height = _this.options._height;
325 | }
326 | }
327 | _this.sliderMainGroup.height = _this.options._height;
328 | _this.sliderMainGroup.x = _this.options._x;
329 | _this.sliderMainGroup.y = _this.options._y;
330 | //
331 | _this.sliderBGGroup.height = _this.options._height;
332 | _this.sliderBGGroup.x = _this.options._x;
333 | _this.sliderBGGroup.y = _this.options._y;
334 |
335 | /// DRAG for horizontal
336 | /*var draggableSprite = _this.game.add.sprite(_this.options._x, _this.options._y);
337 | draggableSprite.width = (_this.options._objects.length+5) * _this.options._width;
338 | draggableSprite.height = _this.options._height;
339 | draggableSprite.y = _this.options._y;
340 | draggableSprite.inputEnabled = true;
341 | draggableSprite.input.enableDrag();
342 | draggableSprite.input.allowVerticalDrag = false;
343 | // draggableSprite.input.enableSnap(_this.options._width, _this.options._height, true, true);
344 | draggableSprite.events.onDragStart.add(_this.onDragStart, _this);
345 | draggableSprite.events.onDragStop.add(_this.onDragStop, _this);
346 | draggableSprite.events.onDragUpdate.add(_this.dragUpdate, _this);
347 | _this._draggableSprite = draggableSprite;*/
348 |
349 | /////// END OF OBJECTS GROUP
350 |
351 | //////// CONTROLS GROUP
352 | _this.sliderControlsGroup = _this.game.add.group();
353 | _this.sliderControlsGroup.width = _this.options._width;
354 | _this.sliderControlsGroup.height = _this.options._height;
355 | _this.sliderControlsGroup.x = _this.options._x;
356 | _this.sliderControlsGroup.y = _this.options._y;
357 |
358 | //////// END OF CONTROLS GROUP
359 |
360 | //MASK
361 | var maskGraphics = game.add.graphics(0, 0);
362 | maskGraphics.beginFill(0xffffff);
363 | maskGraphics.drawRect(_this.options._x, _this.options._y, _this.options._width, _this.options._height);
364 | _this.sliderMainGroup.mask = maskGraphics;
365 |
366 | /// create main bg
367 | if (_this.options.customSliderBG === false) {
368 | bgRect = game.add.graphics(_this.options._width, _this.options._height);
369 | bgRect.beginFill(_this.options.sliderBG, _this.options.sliderBGAlpha);
370 | bgRect.x = _this.options._x;
371 | bgRect.y = _this.options._y;
372 |
373 | bgRect.drawRect(0, 0, _this.options._width, _this.options._height);
374 | _this.sliderMainGroup.add(bgRect);
375 | } else {
376 | _this.sliderBGGroup.add(_this.options.customSliderBG);
377 | }
378 | // add controls
379 | if (_this.options._showHandles === true) {
380 |
381 | var chevronRight;
382 | var chevronLeft;
383 |
384 | if (_this.options._customHandleNext === "") {
385 | chevronRight = game.add.image(0, 0, "slider_chevron_right");
386 | chevronRight.scale.setTo(0.6, 0.6);
387 | } else {
388 | chevronRight = game.add.image(0, 0, _this.options._customHandleNext);
389 | }
390 | chevronRight.x = _this.options._width - (chevronRight.width + 10); //_this.options._x+_this.options._width - (chevronRight.width+10);
391 | chevronRight.y = (_this.options._height / 2) - chevronRight.height / 2;
392 | chevronRight.inputEnabled = true;
393 | chevronRight.events.onInputDown.add(function (e, pointer) {
394 | if (_this.options._onNextCallback) {
395 | _this.options._onNextCallback();
396 | }
397 |
398 | if (_this.tweenObj.isRunning !== true) {
399 | _this.stopSlider();
400 | _this.goToNext();
401 | }
402 |
403 | }, _this);
404 |
405 |
406 | if (_this.options._customHandlePrev === "") {
407 | chevronLeft = game.add.image(0, 0, "slider_chevron_left");
408 | chevronLeft.scale.setTo(0.6, 0.6);
409 | } else {
410 | chevronLeft = game.add.image(0, 0, _this.options._customHandlePrev);
411 | }
412 | chevronLeft.x = 10;
413 | chevronLeft.y = (_this.options._height / 2) - chevronLeft.height / 2;
414 | chevronLeft.inputEnabled = true;
415 | chevronLeft.events.onInputDown.add(function (e, pointer) {
416 | if (_this.options._onPrevCallback) {
417 | _this.options._onPrevCallback();
418 | }
419 |
420 | if (_this.tweenObj.isRunning !== true) {
421 | _this.stopSlider();
422 | _this.goToPrev();
423 | }
424 |
425 | }, _this);
426 |
427 |
428 |
429 | // if not infinite initialy hide it
430 | if (_this.options.infiniteLoop === false) {
431 | chevronLeft.alpha = 0;
432 | }
433 | }
434 | else {
435 |
436 | }
437 |
438 |
439 | // ADDING THE BLOCKS
440 | if (_this.options._objects.length > 0) {
441 | var objArr = _this.options._objects.slice(0);
442 | var length = Number(objArr.length);
443 | for (var i = 0; i < length; i++) {
444 | var x;
445 | var y;
446 | // mode
447 | if (_this.options._mode === "horizontal") {
448 | objArr[i].x = (_this.options._width * i);
449 | } else if (_this.options._mode === "vertical-from-top") {
450 | objArr[i].y = (_this.options._height * i) * -1;
451 |
452 | } else if (_this.options._mode === "vertical-from-bottom") {
453 | objArr[i].y = (_this.options._height * i);
454 | }
455 | _this.sliderMainGroup.add(objArr[i]);
456 | }
457 | _this.options._objects = _this.sliderMainGroup.children;
458 | //window.console.log(_this.options._objects.length, _this.options._objects, _this.sliderMainGroup.children.length);
459 | }
460 |
461 |
462 | // ADDING STATIC ELEMENTS
463 | if(_this.options._staticElements.length > 0) {
464 | for (var i = 0;i<_this.options._staticElements.length;i++ ) {
465 | game.world.bringToTop(_this.options._staticElements[i]);
466 | _this.sliderBGGroup.add(_this.options._staticElements[i]);
467 | }
468 | }
469 |
470 |
471 | // move the chevrons to top
472 | if (_this.options._showHandles === true) {
473 | _this.sliderControlsGroup.add(chevronRight);
474 | _this.sliderControlsGroup.add(chevronLeft);
475 | }
476 |
477 | //////////// AUTO ANIMATE
478 | if (_this.options.autoAnimate === true) {
479 | _this.startSlider();
480 | }
481 |
482 | },
483 | startSlider: function () {
484 | _this.startSlider();
485 | },
486 | stopSlider: function () {
487 | _this.startSlider();
488 | },
489 | moveToSlide: function (index, animate) {
490 |
491 | _this.moveToSlide(index, animate);
492 | },
493 | goToNext: function () {
494 | _this.goToNext();
495 | },
496 | goToPrev: function () {
497 | _this.goToPrev();
498 | },
499 | getCurrentIndex: function () {
500 | return _this.slideIndex;
501 | },
502 | refreshSlider: function() {
503 |
504 | },
505 | removeItemAt: function(index) {
506 | _this.sliderMainGroup.removeChildAt(index);
507 | _this.options._objects = _this.sliderMainGroup.children;
508 | },
509 | hideSlider: function() {
510 | _this.sliderMainGroup.visible = false;
511 | _this.sliderControlsGroup.visible = false;
512 | _this.sliderBGGroup.visible = false;
513 | if(_this._modal) {
514 | _this._modal.visible = false;
515 | }
516 | },
517 | showSlider: function() {
518 | _this.sliderMainGroup.visible = true;
519 | _this.sliderControlsGroup.visible = true;
520 | _this.sliderBGGroup.visible = true;
521 | if(_this._modal) {
522 | _this._modal.visible = true;
523 | }
524 | }
525 | };
526 | };
527 |
--------------------------------------------------------------------------------
/phase-slide.js:
--------------------------------------------------------------------------------
1 | /**
2 | * PHASE-SLIDE IS A UI SLIDER FOR PHASER.IO LIBRARY
3 | *
4 | * COPYWRITE-2015
5 | * AUTHOR: MICHAEL DOBEKIDIS (NETGFX.COM)
6 | *
7 | */
8 |
9 | var phaseSlider = phaseSlider || {};
10 |
11 |
12 | phaseSlider = function(game) {
13 |
14 | var _this = this;
15 |
16 | game.phaseSlider = _this;
17 | _this.game = game;
18 | _this.locked = false;
19 | _this.slideIndex = 0;
20 | _this.slider_timer = null;
21 | _this.tweenObj = {};
22 |
23 | var chevron_left = "";
24 |
25 | var chevron_right = "";
26 |
27 | game.load.image("slider_chevron_left", chevron_left);
28 | game.load.image("slider_chevron_right", chevron_right);
29 |
30 | _this.goToNext = function() {
31 |
32 | if (_this.locked === true) {
33 | return false;
34 | }
35 |
36 | if (_this.options._mode === "horizontal") {
37 | var finalX = _this.sliderMainGroup.x + (_this.options._width * -1);
38 |
39 | if ((_this.slideIndex >= _this.options._objects.length - 1) && _this.options.autoAnimate === false) {
40 | _this.stopSlider();
41 | return false;
42 | }
43 |
44 | // animate loop
45 | if (_this.options.autoAnimate === true) {
46 | if (_this.slideIndex >= _this.options._objects.length - 1) {
47 | _this.slideIndex = 0;
48 | _this.sliderMainGroup.x = _this.options._x;
49 | this.locked = false;
50 | return true;
51 | }
52 | }
53 | _this.locked = true;
54 |
55 | _this.tweenObj = game.add.tween(_this.sliderMainGroup).to({
56 | x: finalX
57 | }, _this.options.animationDuration, _this.options.animationEasing, true, 0, 0, false);
58 | _this.tweenObj.onComplete.add(function() {
59 | this.locked = false;
60 | this.slideIndex += 1;
61 | if (_this.options.autoAnimate === false && this.slideIndex >= _this.options._objects.length - 1) {
62 | if (_this.options._showHandles === true) {
63 | this.sliderControlsGroup.children[0].alpha = 0;
64 | }
65 | }
66 |
67 | // enable prev
68 | if (_this.options._showHandles === true) {
69 | this.sliderControlsGroup.children[1].alpha = 1;
70 | }
71 | }, _this);
72 | } else {
73 |
74 | var finalY;
75 | if (_this.options._mode === "vertical-from-top") {
76 | finalY = _this.sliderMainGroup.y + (_this.options._height);
77 | } else if (_this.options._mode === "vertical-from-bottom") {
78 | finalY = _this.sliderMainGroup.y + (_this.options._height * -1);
79 | }
80 |
81 | if ((_this.slideIndex >= _this.options._objects.length - 1) && _this.options.autoAnimate === false) {
82 | _this.stopSlider();
83 | return false;
84 | }
85 |
86 | // animate loop
87 | if (_this.options.autoAnimate === true) {
88 | if (_this.slideIndex >= _this.options._objects.length - 1) {
89 | _this.slideIndex = 0;
90 | _this.sliderMainGroup.y = _this.options._y;
91 | this.locked = false;
92 | return true;
93 | }
94 | }
95 |
96 | _this.locked = true;
97 |
98 | _this.tweenObj = game.add.tween(_this.sliderMainGroup).to({
99 | y: finalY
100 | }, _this.options.animationDuration, _this.options.animationEasing, true, 0, 0, false);
101 | _this.tweenObj.onComplete.add(function() {
102 | this.locked = false;
103 | this.slideIndex += 1;
104 |
105 | if (_this.options.autoAnimate === false && this.slideIndex >= _this.options._objects.length - 1) {
106 | if (_this.options._showHandles === true) {
107 | this.sliderControlsGroup.children[0].alpha = 0;
108 | }
109 | }
110 |
111 | // enable prev
112 | if (_this.options._showHandles === true) {
113 | this.sliderControlsGroup.children[1].alpha = 1;
114 | }
115 | }, _this);
116 | }
117 | };
118 | _this.goToPrev = function() {
119 |
120 | if (_this.locked === true) {
121 | return false;
122 | }
123 |
124 | if (_this.options._mode === "horizontal") {
125 | var finalX = _this.sliderMainGroup.x + (_this.options._width);
126 |
127 | if (_this.slideIndex <= 0 && _this.options.autoAnimate === false) {
128 | _this.stopSlider();
129 | return false;
130 | }
131 |
132 | _this.locked = true;
133 | _this.tweenObj = game.add.tween(_this.sliderMainGroup).to({
134 | x: finalX
135 | }, _this.options.animationDuration, _this.options.animationEasing, true, 0, 0, false);
136 | _this.tweenObj.onComplete.add(function() {
137 | this.locked = false;
138 | this.slideIndex -= 1;
139 |
140 | if (this.slideIndex < 0) {
141 | this.slideIndex = 0;
142 | }
143 |
144 | if (_this.options.infiniteLoop === false && this.slideIndex <= 0) {
145 | // enable prev
146 | if (_this.options._showHandles === true) {
147 | this.sliderControlsGroup.children[1].alpha = 0;
148 | }
149 | }
150 |
151 | // enable next
152 | if (_this.options._showHandles === true) {
153 | this.sliderControlsGroup.children[0].alpha = 1;
154 | }
155 |
156 | }, _this);
157 | } else {
158 | var finalY;
159 | if (_this.options._mode === "vertical-from-top") {
160 | finalY = _this.sliderMainGroup.y + (_this.options._height * -1);
161 | } else if (_this.options._mode === "vertical-from-bottom") {
162 | finalY = _this.sliderMainGroup.y + (_this.options._height);
163 | }
164 | if (_this.slideIndex <= 0 && _this.options.autoAnimate === false) {
165 | _this.stopSlider();
166 | return false;
167 | }
168 | _this.locked = true;
169 | _this.tweenObj = game.add.tween(_this.sliderMainGroup).to({
170 | y: finalY
171 | }, _this.options.animationDuration, _this.options.animationEasing, true, 0, 0, false);
172 | _this.tweenObj.onComplete.add(function() {
173 | this.locked = false;
174 | this.slideIndex -= 1;
175 |
176 | if (this.slideIndex < 0) {
177 | this.slideIndex = 0;
178 | }
179 |
180 | if (_this.options.autoAnimate === false && this.slideIndex <= 0) {
181 | if (_this.options._showHandles === true) {
182 | this.sliderControlsGroup.children[1].alpha = 0;
183 | }
184 | }
185 |
186 | // enable prev
187 | if (_this.options._showHandles === true) {
188 | this.sliderControlsGroup.children[0].alpha = 1;
189 | }
190 | }, _this);
191 | }
192 | };
193 |
194 | _this.startSlider = function() {
195 | var _timer = game.time.create(false);
196 | _timer.start();
197 | _timer.loop(Phaser.Timer.SECOND * _this.options.animationDelay, _this.goToNext, _this);
198 | _this.slider_timer = _timer;
199 | };
200 | _this.stopSlider = function() {
201 | if (_this.slider_timer !== null) {
202 | _this.slider_timer.stop(true);
203 | _this.slider_timer = null;
204 | } else {
205 | return false;
206 | }
207 | };
208 |
209 | _this.moveToSlide = function(index, animate) {
210 | var finalX;
211 | if (index >= _this.options._objects.length) {
212 | return false;
213 | }
214 | if (_this.options._mode === "horizontal") {
215 | finalX = (_this.options._x - (_this.options._width * (index)));
216 | if (animate === true) {
217 |
218 | var tweenObj = game.add.tween(_this.sliderMainGroup).to({
219 | x: finalX
220 | }, _this.options.animationDuration, _this.options.animationEasing, true, 0, 0, false);
221 | } else {
222 | _this.sliderMainGroup.x = finalX;
223 | }
224 | } else if (_this.options._mode === "vertical-from-top") {
225 | //TODO: ADD VERTICAL-FROM-TOP
226 | } else if (_this.options._mode === "vertical-from-bottom") {
227 | //TODO: ADD VERTICAL-FROM-BOTTOM
228 | }
229 | };
230 | /////////////////////////////////////////////////////////////////////////////////////////
231 | ///
232 | _this.onDragStart = function(sprite, pointer, dragX, dragY) {
233 | _this.dragInit = pointer.x;
234 | _this.lastDrag = pointer.x;
235 | };
236 |
237 | _this.onDragStop = function(e) {
238 |
239 | };
240 | _this.dragUpdate = function(sprite, pointer, dragX, dragY) {
241 |
242 | var finalX = dragX; // - _this.options._x;
243 | // going left
244 | if (pointer.x < _this.dragInit) {
245 | var diff = Math.abs(pointer.x) - Math.abs(_this.lastDrag);
246 | // going right
247 | if (diff < 0) {
248 | finalX = _this.sliderMainGroup.x - 1;
249 | } else {
250 | finalX = _this.sliderMainGroup.x + 1;
251 | }
252 | } else {
253 | var diff = Math.abs(pointer.x) - Math.abs(_this.lastDrag);
254 | // going right
255 | if (diff < 0) {
256 | finalX = _this.sliderMainGroup.x - 1;
257 | } else {
258 | finalX = _this.sliderMainGroup.x + 1;
259 | }
260 | }
261 |
262 | if (finalX <= (_this.options._x + (_this.options._width * (_this.options._objects.length - 2))) * -1) {
263 | finalX = (_this.options._x + (_this.options._width * (_this.options._objects.length - 2))) * -1;
264 | } else if (finalX >= _this.options._x) {
265 | finalX = _this.options._x;
266 | }
267 | _this.sliderMainGroup.x = finalX;
268 | _this.lastDrag = pointer.x;
269 | };
270 |
271 | return {
272 | createSlider: function(options) {
273 | // initialize index
274 | _this.slideIndex = 0;
275 |
276 | _this.options = {
277 | _mode: options.mode || "horizontal", // horizontal, vertical-from-top, vertical-from-bottom
278 | _width: options.width || 500,
279 | _height: options.height || 400,
280 | _animationEffect: options.animationEffect || "slide", // slide, fade, cover
281 | autoAnimate: options.autoAnimate || false,
282 | infiniteLoop: options.infiniteLoop || false,
283 | animationDelay: options.animationDelay || 2,
284 | animationDuration: options.animationDuration || 600,
285 | animationEasing: options.animationEasing || Phaser.Easing.Cubic.Out, //Phaser.Easing.Linear.None,
286 | _x: options.x || 0,
287 | _y: options.y || 0,
288 | _objects: options.objects || [], // can take: single-sprite, single-image, group
289 | sliderBG: options.sliderBG || 0x35d2e0,
290 | customSliderBG: options.customSliderBG || false,
291 | sliderBGAlpha: options.sliderBGAlpha || 1,
292 | _customHandleNext: options.customHandleNext || "",
293 | _customHandlePrev: options.customHandlePrev || "",
294 | _showHandles: options.showHandles == undefined ? true : options.showHandles,
295 | _onPreNextCallback: options.onPreNextCallback || false,
296 | _onPrePrevCallback: options.onPrePrevCallback || false,
297 | _onAfterNextCallback: options.onAfterNextCallback || false,
298 | _onAfterPrevCallback: options.onAfterPreCallback || false,
299 | _addModal: options.modal || false,
300 | _modalAlpha: options.modalAlpha || 0.7,
301 | _staticElements: options.staticElements || []
302 | };
303 |
304 | //////////////////////////////////////////////////////////////////////////////////////////////
305 |
306 | var bgRect;
307 | _this._modal = {};
308 | if (_this.options._addModal === true) {
309 | _this._modal = game.add.graphics(game.width, game.height);
310 | _this._modal.beginFill(0x000000, _this.options._modalAlpha);
311 | _this._modal.x = 0;
312 | _this._modal.y = 0;
313 | _this._modal.inputEnabled = true;
314 | _this._modal.drawRect(0, 0, _this.game.width, _this.game.height);
315 | } else {
316 | _this._modal = false;
317 | }
318 |
319 | //////// OBJECTS GROUP
320 | ///
321 | _this.sliderBGGroup = _this.game.add.group();
322 | _this.sliderMainGroup = _this.game.add.group();
323 | _this.sliderBGGroup.width = _this.options._width;
324 | _this.sliderMainGroup.width = _this.options._width;
325 | if (_this.options._mode === "horizontal") {
326 | _this.sliderMainGroup.width = _this.options._width * _this.options._objects.length;
327 |
328 | // if used as a placeholder don't make the width = 0
329 | if (_this.options._objects.length === 0) {
330 | _this.sliderMainGroup.width = _this.options._width;
331 | }
332 | } else {
333 | _this.sliderMainGroup.height = _this.options._height * _this.options._objects.length;
334 |
335 | // if used as a placeholder don't make the height = 0
336 | if (_this.options._objects.length === 0) {
337 | _this.sliderMainGroup.height = _this.options._height;
338 | }
339 | }
340 | _this.sliderMainGroup.height = _this.options._height;
341 | _this.sliderMainGroup.x = _this.options._x;
342 | _this.sliderMainGroup.y = _this.options._y;
343 | //
344 | _this.sliderBGGroup.height = _this.options._height;
345 | _this.sliderBGGroup.x = _this.options._x;
346 | _this.sliderBGGroup.y = _this.options._y;
347 |
348 | /// DRAG for horizontal
349 | /*var draggableSprite = _this.game.add.sprite(_this.options._x, _this.options._y);
350 | draggableSprite.width = (_this.options._objects.length+5) * _this.options._width;
351 | draggableSprite.height = _this.options._height;
352 | draggableSprite.y = _this.options._y;
353 | draggableSprite.inputEnabled = true;
354 | draggableSprite.input.enableDrag();
355 | draggableSprite.input.allowVerticalDrag = false;
356 | // draggableSprite.input.enableSnap(_this.options._width, _this.options._height, true, true);
357 | draggableSprite.events.onDragStart.add(_this.onDragStart, _this);
358 | draggableSprite.events.onDragStop.add(_this.onDragStop, _this);
359 | draggableSprite.events.onDragUpdate.add(_this.dragUpdate, _this);
360 | _this._draggableSprite = draggableSprite;*/
361 |
362 | /////// END OF OBJECTS GROUP
363 |
364 | //////// CONTROLS GROUP
365 | _this.sliderControlsGroup = _this.game.add.group();
366 | _this.sliderControlsGroup.width = _this.options._width;
367 | _this.sliderControlsGroup.height = _this.options._height;
368 | _this.sliderControlsGroup.x = _this.options._x;
369 | _this.sliderControlsGroup.y = _this.options._y;
370 |
371 | //////// END OF CONTROLS GROUP
372 |
373 | //MASK
374 | var maskGraphics = game.add.graphics(0, 0);
375 | maskGraphics.beginFill(0xffffff);
376 | maskGraphics.drawRect(_this.options._x, _this.options._y, _this.options._width, _this.options._height);
377 | _this.sliderMainGroup.mask = maskGraphics;
378 |
379 | /// create main bg
380 | if (_this.options.customSliderBG === false) {
381 | bgRect = game.add.graphics(_this.options._width, _this.options._height);
382 | bgRect.beginFill(_this.options.sliderBG, _this.options.sliderBGAlpha);
383 | bgRect.x = _this.options._x;
384 | bgRect.y = _this.options._y;
385 |
386 | bgRect.drawRect(0, 0, _this.options._width, _this.options._height);
387 | _this.sliderMainGroup.add(bgRect);
388 | } else {
389 | _this.sliderBGGroup.add(_this.options.customSliderBG);
390 | }
391 | // add controls
392 | if (_this.options._showHandles === true) {
393 |
394 | var chevronRight;
395 | var chevronLeft;
396 |
397 | if (_this.options._customHandleNext === "") {
398 | chevronRight = game.add.image(0, 0, "slider_chevron_right");
399 | chevronRight.scale.setTo(0.6, 0.6);
400 | } else {
401 | chevronRight = game.add.image(0, 0, _this.options._customHandleNext);
402 | }
403 | chevronRight.x = _this.options._width - (chevronRight.width + 10); //_this.options._x+_this.options._width - (chevronRight.width+10);
404 | chevronRight.y = (_this.options._height / 2) - chevronRight.height / 2;
405 | chevronRight.inputEnabled = true;
406 | chevronRight.events.onInputDown.add(function(e, pointer) {
407 | if (_this.options._onPreNextCallback) {
408 | _this.options._onPreNextCallback();
409 | }
410 |
411 | if (_this.tweenObj.isRunning !== true) {
412 | _this.stopSlider();
413 | _this.goToNext();
414 | }
415 |
416 | if (_this.options._onAfterNextCallback) {
417 | _this.options._onAfterNextCallback();
418 | }
419 |
420 | }, _this);
421 |
422 |
423 | if (_this.options._customHandlePrev === "") {
424 | chevronLeft = game.add.image(0, 0, "slider_chevron_left");
425 | chevronLeft.scale.setTo(0.6, 0.6);
426 | } else {
427 | chevronLeft = game.add.image(0, 0, _this.options._customHandlePrev);
428 | }
429 | chevronLeft.x = 10;
430 | chevronLeft.y = (_this.options._height / 2) - chevronLeft.height / 2;
431 | chevronLeft.inputEnabled = true;
432 | chevronLeft.events.onInputDown.add(function(e, pointer) {
433 | if (_this.options._onPrePrevCallback) {
434 | _this.options._onPrePrevCallback();
435 | }
436 |
437 | if (_this.tweenObj.isRunning !== true) {
438 | _this.stopSlider();
439 | _this.goToPrev();
440 | }
441 |
442 | if (_this.options._onAfterPrevCallback) {
443 | _this.options._onAfterPrevCallback();
444 | }
445 |
446 | }, _this);
447 |
448 |
449 |
450 | // if not infinite initialy hide it
451 | if (_this.options.infiniteLoop === false) {
452 | chevronLeft.alpha = 0;
453 | }
454 | } else {
455 |
456 | }
457 |
458 |
459 | // ADDING THE BLOCKS
460 | if (_this.options._objects.length > 0) {
461 | var objArr = _this.options._objects.slice(0);
462 | var length = Number(objArr.length);
463 | for (var i = 0; i < length; i++) {
464 | var x;
465 | var y;
466 | // mode
467 | if (_this.options._mode === "horizontal") {
468 | objArr[i].x = (_this.options._width * i);
469 | } else if (_this.options._mode === "vertical-from-top") {
470 | objArr[i].y = (_this.options._height * i) * -1;
471 |
472 | } else if (_this.options._mode === "vertical-from-bottom") {
473 | objArr[i].y = (_this.options._height * i);
474 | }
475 | _this.sliderMainGroup.add(objArr[i]);
476 | }
477 | _this.options._objects = _this.sliderMainGroup.children;
478 | //window.console.log(_this.options._objects.length, _this.options._objects, _this.sliderMainGroup.children.length);
479 | }
480 |
481 |
482 | // ADDING STATIC ELEMENTS
483 | if (_this.options._staticElements.length > 0) {
484 | for (var i = 0; i < _this.options._staticElements.length; i++) {
485 | game.world.bringToTop(_this.options._staticElements[i]);
486 | _this.sliderBGGroup.add(_this.options._staticElements[i]);
487 | }
488 | }
489 |
490 |
491 | // move the chevrons to top
492 | if (_this.options._showHandles === true) {
493 | _this.sliderControlsGroup.add(chevronRight);
494 | _this.sliderControlsGroup.add(chevronLeft);
495 | }
496 |
497 | //////////// AUTO ANIMATE
498 | if (_this.options.autoAnimate === true) {
499 | _this.startSlider();
500 | }
501 |
502 | },
503 | startSlider: function() {
504 | _this.startSlider();
505 | },
506 | stopSlider: function() {
507 | _this.startSlider();
508 | },
509 | moveToSlide: function(index, animate) {
510 |
511 | _this.moveToSlide(index, animate);
512 | },
513 | goToNext: function() {
514 | _this.goToNext();
515 | },
516 | goToPrev: function() {
517 | _this.goToPrev();
518 | },
519 | getCurrentIndex: function() {
520 | return _this.slideIndex;
521 | },
522 | refreshSlider: function() {
523 |
524 | },
525 | removeItemAt: function(index) {
526 | _this.sliderMainGroup.removeChildAt(index);
527 | _this.options._objects = _this.sliderMainGroup.children;
528 | },
529 | hideSlider: function() {
530 | _this.sliderMainGroup.visible = false;
531 | _this.sliderControlsGroup.visible = false;
532 | _this.sliderBGGroup.visible = false;
533 | if (_this._modal) {
534 | _this._modal.visible = false;
535 | }
536 | },
537 | showSlider: function() {
538 | _this.sliderMainGroup.visible = true;
539 | _this.sliderControlsGroup.visible = true;
540 | _this.sliderBGGroup.visible = true;
541 | if (_this._modal) {
542 | _this._modal.visible = true;
543 | }
544 | }
545 | };
546 | };
547 |
--------------------------------------------------------------------------------
/phase-slider.min.js:
--------------------------------------------------------------------------------
1 | var phaseSlider=phaseSlider||{};phaseSlider=function(o){var i=this;o.phaseSlider=i,i.game=o,i.locked=!1,i.slideIndex=0,i.slider_timer=null,i.tweenObj={};var t="",e="";return o.load.image("slider_chevron_left",t),o.load.image("slider_chevron_right",e),i.goToNext=function(){if(i.locked=!0,"horizontal"===i.options._mode){var t=i.sliderMainGroup.x+-1*i.options._width;if(i.slideIndex>=i.options._objects.length-1&&i.options.autoAnimate===!1)return i.stopSlider(),!1;if(i.options.autoAnimate===!0&&i.slideIndex>=i.options._objects.length-1)return i.slideIndex=0,i.sliderMainGroup.x=i.options._x,this.locked=!1,!0;i.tweenObj=o.add.tween(i.sliderMainGroup).to({x:t},i.options.animationDuration,i.options.animationEasing,!0,0,0,!1),i.tweenObj.onComplete.add(function(){this.locked=!1,this.slideIndex+=1,i.options.autoAnimate===!1&&this.slideIndex>=i.options._objects.length-1&&i.options._showHandles===!0&&(this.sliderControlsGroup.children[0].alpha=0),i.options._showHandles===!0&&(this.sliderControlsGroup.children[1].alpha=1)},i)}else{var e;if("vertical-from-top"===i.options._mode?e=i.sliderMainGroup.y+i.options._height:"vertical-from-bottom"===i.options._mode&&(e=i.sliderMainGroup.y+-1*i.options._height),i.slideIndex>=i.options._objects.length-1&&i.options.autoAnimate===!1)return i.stopSlider(),!1;if(i.options.autoAnimate===!0&&i.slideIndex>=i.options._objects.length-1)return i.slideIndex=0,i.sliderMainGroup.y=i.options._y,this.locked=!1,!0;i.tweenObj=o.add.tween(i.sliderMainGroup).to({y:e},i.options.animationDuration,i.options.animationEasing,!0,0,0,!1),i.tweenObj.onComplete.add(function(){this.locked=!1,this.slideIndex+=1,i.options.autoAnimate===!1&&this.slideIndex>=i.options._objects.length-1&&i.options._showHandles===!0&&(this.sliderControlsGroup.children[0].alpha=0),i.options._showHandles===!0&&(this.sliderControlsGroup.children[1].alpha=1)},i)}},i.goToPrev=function(){if(i.locked=!0,"horizontal"===i.options._mode){var t=i.sliderMainGroup.x+i.options._width;if(i.slideIndex<=0&&i.options.autoAnimate===!1)return i.stopSlider(),!1;i.tweenObj=o.add.tween(i.sliderMainGroup).to({x:t},i.options.animationDuration,i.options.animationEasing,!0,0,0,!1),i.tweenObj.onComplete.add(function(){this.locked=!1,this.slideIndex-=1,this.slideIndex<0&&(this.slideIndex=0),i.options.infiniteLoop===!1&&this.slideIndex<=0&&i.options._showHandles===!0&&(this.sliderControlsGroup.children[1].alpha=0),i.options._showHandles===!0&&(this.sliderControlsGroup.children[0].alpha=1)},i)}else{var e;if("vertical-from-top"===i.options._mode?e=i.sliderMainGroup.y+-1*i.options._height:"vertical-from-bottom"===i.options._mode&&(e=i.sliderMainGroup.y+i.options._height),i.slideIndex<=0&&i.options.autoAnimate===!1)return i.stopSlider(),!1;i.tweenObj=o.add.tween(i.sliderMainGroup).to({y:e},i.options.animationDuration,i.options.animationEasing,!0,0,0,!1),i.tweenObj.onComplete.add(function(){this.locked=!1,this.slideIndex-=1,this.slideIndex<0&&(this.slideIndex=0),i.options.autoAnimate===!1&&this.slideIndex<=0&&i.options._showHandles===!0&&(this.sliderControlsGroup.children[1].alpha=0),i.options._showHandles===!0&&(this.sliderControlsGroup.children[0].alpha=1)},i)}},i.startSlider=function(){var t=o.time.create(!1);t.start(),t.loop(Phaser.Timer.SECOND*i.options.animationDelay,i.goToNext,i),i.slider_timer=t},i.stopSlider=function(){return null===i.slider_timer?!1:(i.slider_timer.stop(!0),void(i.slider_timer=null))},i.moveToSlide=function(t,e){var n;if(t>=i.options._objects.length)return!1;if("horizontal"===i.options._mode)if(n=i.options._x-i.options._width*t,e===!0){o.add.tween(i.sliderMainGroup).to({x:n},i.options.animationDuration,i.options.animationEasing,!0,0,0,!1)}else i.sliderMainGroup.x=n;else"vertical-from-top"===i.options._mode||"vertical-from-bottom"===i.options._mode},i.onDragStart=function(o,t,e,n){i.dragInit=t.x,i.lastDrag=t.x},i.onDragStop=function(o){},i.dragUpdate=function(o,t,e,n){var s=e;if(t.xa?i.sliderMainGroup.x-1:i.sliderMainGroup.x+1}else{var a=Math.abs(t.x)-Math.abs(i.lastDrag);s=0>a?i.sliderMainGroup.x-1:i.sliderMainGroup.x+1}s<=-1*(i.options._x+i.options._width*(i.options._objects.length-2))?s=-1*(i.options._x+i.options._width*(i.options._objects.length-2)):s>=i.options._x&&(s=i.options._x),i.sliderMainGroup.x=s,i.lastDrag=t.x},{createSlider:function(t){i.slideIndex=0,i.options={_mode:t.mode||"horizontal",_width:t.width||500,_height:t.height||400,_animationEffect:t.animationEffect||"slide",autoAnimate:t.autoAnimate||!1,infiniteLoop:t.infiniteLoop||!1,animationDelay:t.animationDelay||2,animationDuration:t.animationDuration||600,animationEasing:t.animationEasing||Phaser.Easing.Cubic.Out,_x:t.x||0,_y:t.y||0,_objects:t.objects||[],sliderBG:t.sliderBG||3527392,customSliderBG:t.customSliderBG||!1,sliderBGAlpha:t.sliderBGAlpha||1,_customHandleNext:t.customHandleNext||"",_customHandlePrev:t.customHandlePrev||"",_showHandles:void 0==t.showHandles?!0:t.showHandles,_onNextCallback:t.onNextCallback||!1,_onPrevCallback:t.onPrevCallback||!1,_addModal:t.modal||!1,_modalAlpha:t.modalAlpha||.7,_staticElements:t.staticElements||[]};var e;i._modal={},i.options._addModal===!0?(i._modal=o.add.graphics(o.width,o.height),i._modal.beginFill(0,i.options._modalAlpha),i._modal.x=0,i._modal.y=0,i._modal.inputEnabled=!0,i._modal.drawRect(0,0,i.game.width,i.game.height)):i._modal=!1,i.sliderBGGroup=i.game.add.group(),i.sliderMainGroup=i.game.add.group(),i.sliderBGGroup.width=i.options._width,i.sliderMainGroup.width=i.options._width,"horizontal"===i.options._mode?(i.sliderMainGroup.width=i.options._width*i.options._objects.length,0===i.options._objects.length&&(i.sliderMainGroup.width=i.options._width)):(i.sliderMainGroup.height=i.options._height*i.options._objects.length,0===i.options._objects.length&&(i.sliderMainGroup.height=i.options._height)),i.sliderMainGroup.height=i.options._height,i.sliderMainGroup.x=i.options._x,i.sliderMainGroup.y=i.options._y,i.sliderBGGroup.height=i.options._height,i.sliderBGGroup.x=i.options._x,i.sliderBGGroup.y=i.options._y,i.sliderControlsGroup=i.game.add.group(),i.sliderControlsGroup.width=i.options._width,i.sliderControlsGroup.height=i.options._height,i.sliderControlsGroup.x=i.options._x,i.sliderControlsGroup.y=i.options._y;var n=o.add.graphics(0,0);if(n.beginFill(16777215),n.drawRect(i.options._x,i.options._y,i.options._width,i.options._height),i.sliderMainGroup.mask=n,i.options.customSliderBG===!1?(e=o.add.graphics(i.options._width,i.options._height),e.beginFill(i.options.sliderBG,i.options.sliderBGAlpha),e.x=i.options._x,e.y=i.options._y,e.drawRect(0,0,i.options._width,i.options._height),i.sliderMainGroup.add(e)):i.sliderBGGroup.add(i.options.customSliderBG),i.options._showHandles===!0){var s,a;""===i.options._customHandleNext?(s=o.add.image(0,0,"slider_chevron_right"),s.scale.setTo(.6,.6)):s=o.add.image(0,0,i.options._customHandleNext),s.x=i.options._width-(s.width+10),s.y=i.options._height/2-s.height/2,s.inputEnabled=!0,s.events.onInputDown.add(function(o,t){i.options._onNextCallback&&i.options._onNextCallback(),i.tweenObj.isRunning!==!0&&(i.stopSlider(),i.goToNext())},i),""===i.options._customHandlePrev?(a=o.add.image(0,0,"slider_chevron_left"),a.scale.setTo(.6,.6)):a=o.add.image(0,0,i.options._customHandlePrev),a.x=10,a.y=i.options._height/2-a.height/2,a.inputEnabled=!0,a.events.onInputDown.add(function(o,t){i.options._onPrevCallback&&i.options._onPrevCallback(),i.tweenObj.isRunning!==!0&&(i.stopSlider(),i.goToPrev())},i),i.options.infiniteLoop===!1&&(a.alpha=0)}if(i.options._objects.length>0){for(var d=i.options._objects.slice(0),r=Number(d.length),l=0;r>l;l++){"horizontal"===i.options._mode?d[l].x=i.options._width*l:"vertical-from-top"===i.options._mode?d[l].y=i.options._height*l*-1:"vertical-from-bottom"===i.options._mode&&(d[l].y=i.options._height*l),i.sliderMainGroup.add(d[l])}i.options._objects=i.sliderMainGroup.children}if(i.options._staticElements.length>0)for(var l=0;l