Slider: Add some documentation
parent
573fa3806c
commit
9c4fd1d94c
|
|
@ -0,0 +1,97 @@
|
|||
Slider Library
|
||||
========================
|
||||
|
||||
> Take a look at README.md for hints on developing with this library.
|
||||
|
||||
Usage
|
||||
-----
|
||||
|
||||
```JS
|
||||
var Slider = require("Slider");
|
||||
var slider = Slider(callbackFunction, configObject);
|
||||
|
||||
Bangle.on("drag", slider.f.dragSlider);
|
||||
|
||||
// If the slider should take precedent over other drag handlers use (fw2v18 and up):
|
||||
// Bangle.prependListener("drag", slider.f.dragSlider);
|
||||
```
|
||||
|
||||
`callbackFunction` (first argument) determines what `slider` is used for. Should take two arguments, `mode` and `feedback`. The different modes/feedback combinations to expect are:
|
||||
- "map", o.v.level | current level when interacting by mapping interface.
|
||||
- "incr", incr | where incr = +-1, when interacting by incrementing interface.
|
||||
- "remove", o.v.level | last level when the slider times out.
|
||||
- "auto" | on its own, when auto progressing.
|
||||
|
||||
`configObject` (second argument, optional) has the following defaults:
|
||||
|
||||
```JSON
|
||||
R = Bangle.appRect; // For use when determining defaults below.
|
||||
|
||||
{
|
||||
useMap:false, // Use the mapping feature?
|
||||
useIncr:true, // Use the incementing feature?
|
||||
horizontal:false, // Slider should be horizontal?
|
||||
xStart:R.x2-R.w/4-4, // Leftmost x-coordinate. (Uppermost y-coordingat if horizontal)
|
||||
width:R.w/4, // Width of the slider. (Height if horizontal)
|
||||
yStart:R.y+4, // Uppermost y-coordinate. (Rightmost x-coordinate if horizontal)
|
||||
height:R.h-10, // Height of the slider. (Width if horizontal)
|
||||
steps:30, // Number of discrete steps of the slider.
|
||||
oversizeR:0, // Determines if the mapping area should be extend outside the indicator (Right/Up).
|
||||
oversizeL:0, // Determines if the mapping area should be extend outside the indicator (Left/Down).
|
||||
timeout:1, // Second untill the slider times out.
|
||||
colorFG:g.theme.fg2, // Forground color.
|
||||
colorBG:g.theme.bg2, // Background color.
|
||||
rounded:true, // Slider should have rounded corners?
|
||||
propagateDrag:false, // Pass the drag event on down the handler chain?
|
||||
autoProgress:false, // The slider should be able to progress automatically?
|
||||
outerBorderSize:2, // The size of the visual border.
|
||||
innerBorderSize:2, // The distance between visual border and the slider.
|
||||
drawableSlider:true, // Should supply the sliders standard drawing mechanism?
|
||||
dragableSlider:true, // Should supply the sliders standard interaction mechanisms?
|
||||
currLevel:undefined, // The level to initate the slider with.
|
||||
dragRect:R, // Accept input withing this rectangle.
|
||||
}
|
||||
```
|
||||
|
||||
A slider initiated in the Web IDE terminal reveals its internals to a degree:
|
||||
```
|
||||
>slider = require("Slider").create(()=>{},{autoProgress:true})
|
||||
={
|
||||
v: { level: 15, ebLast: 0, dy: 0 },
|
||||
f: {
|
||||
wasOnDragRect: function (exFirst,eyFirst) { ... },
|
||||
wasOnIndicator: function (exFirst) { ... },
|
||||
dragSlider: function (e) { ... },
|
||||
remove: function () { ... },
|
||||
updateBar: function (levelHeight) { ... },
|
||||
draw: function (level) { ... },
|
||||
autoUpdate: function () { ... },
|
||||
updateInitTime: function () { ... },
|
||||
startAutoUpdate: function () { ... },
|
||||
stopAutoUpdate: function () { ... }
|
||||
},
|
||||
c: { useMap: false, useIncr: true, horizontal: false, xStart: 127,
|
||||
width: 44, yStart: 28, height: 142, steps: 30, oversizeR: 0,
|
||||
oversizeL: 0, timeout: 1, colorFG: 65535, colorBG: 8, rounded: 20,
|
||||
propagateDrag: false, autoProgress: true, outerBorderSize: 2, innerBorderSize: 2,
|
||||
drawableSlider: true, dragableSlider: true, currLevel: undefined,
|
||||
dragRect: { x: 0, y: 24, w: 176, h: 152,
|
||||
x2: 175, y2: 175 },
|
||||
_xStart: 131, _width: 36, _yStart: 32, _height: 134, STEP_SIZE: 3.36666666666,
|
||||
r: { x: 127, y: 28, x2: 171, y2: 170,
|
||||
w: 44, h: 142 },
|
||||
borderRect: { x: 127, y: 28, w: 44, h: 142,
|
||||
r: 20 },
|
||||
hollowRect: { x: 129, y: 30, w: 40, h: 138,
|
||||
r: 20 }
|
||||
}
|
||||
}
|
||||
>
|
||||
```
|
||||
|
||||
Links
|
||||
-----
|
||||
|
||||
There is a [slider test app on thyttan's personal app loader](https://thyttan.github.io/BangleApps/?q=slidertest) (at time of writing). Looking at [its code](https://github.com/thyttan/BangleApps/blob/ui-slider-lib/apps/slidertest/app.js) is a good way to see how the slider is used in app development.
|
||||
|
||||
The version of [Remote for Spotify on thyttan's personal app loader](https://thyttan.github.io/BangleApps/?q=spotrem) (at time of writing) also utilizes the `Slider` module. Here is [the code](https://github.com/thyttan/BangleApps/blob/ui-slider-lib/apps/spotrem/app.js).
|
||||
Loading…
Reference in New Issue