annotate webapp/src/main/webapp/jquery/jquery.digilib.sliders.js @ 1079:9c2abceb05c5

brightness min- and max- values scale with contrast settings (not yet for rgb). fixed bug with dismissing the rgb sliders window.
author robcast
date Thu, 24 May 2012 14:35:43 +0200
parents b41dc00af960
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1022
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
1 /**
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
2 digilib sliders plugin
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
3 */
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
4
1071
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
5 // TODO:
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
6 // IE sets rgb contrast sliders initially to 0.4 instead of 0 - ???
1022
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
7
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
8 (function($) {
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
9 // plugin object with digilib data
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
10 var digilib = null;
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
11 // the functions made available by digilib
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
12 var fn = null;
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
13 // affine geometry plugin
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
14 var geom = null;
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
15
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
16 var defaults = {};
1022
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
17
1042
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
18 var sliderOptions = {
1022
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
19 rot : {
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
20 label : "Rotation angle",
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
21 tooltip : "rotate image",
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
22 icon : "rotate.png",
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
23 preview : false,
1071
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
24 min : 0,
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
25 max : 360,
1079
9c2abceb05c5 brightness min- and max- values scale with contrast settings (not yet for rgb).
robcast
parents: 1076
diff changeset
26 step : 5,
1076
b41dc00af960 default value for rotate is 0
robcast
parents: 1071
diff changeset
27 start : 0
1022
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
28 },
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
29 brgt : {
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
30 label : "Brightness",
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
31 tooltip : "set numeric value to be added",
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
32 icon : "brightness.png",
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
33 preview : true,
1071
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
34 min : -255,
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
35 max : 255,
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
36 step : 10,
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
37 start : 0
1022
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
38 },
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
39 cont : {
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
40 label : "Contrast",
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
41 tooltip : "set numeric value to be multiplied",
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
42 icon : "contrast.png",
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
43 preview : true,
1071
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
44 min : -4,
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
45 max : 4,
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
46 step : 0.1,
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
47 start : 0
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
48 }
1022
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
49 };
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
50
1058
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
51 var primaryColors = ['r', 'g', 'b'];
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
52 var colorVals = {
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
53 r : {
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
54 label : "red",
1058
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
55 color : "#800000",
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
56 a : 0,
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
57 m : 0
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
58 },
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
59 g : {
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
60 label : "green",
1058
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
61 color : "#008000",
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
62 a : 0,
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
63 m : 0
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
64 },
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
65 b : {
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
66 label : "blue",
1058
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
67 color : "#000080",
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
68 a : 0,
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
69 m : 0
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
70 },
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
71 brgt : 0,
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
72 cont : 0
1079
9c2abceb05c5 brightness min- and max- values scale with contrast settings (not yet for rgb).
robcast
parents: 1076
diff changeset
73 };
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
74
1022
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
75 var actions = {
1038
a79be2432eb4 put new slider code back into sliders plugin
hertzhaft
parents: 1029
diff changeset
76 // shows brightness slider
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
77 sliderBrgt : function (data) {
1079
9c2abceb05c5 brightness min- and max- values scale with contrast settings (not yet for rgb).
robcast
parents: 1076
diff changeset
78 // adjust min and max for contrast value (not nice to change sliderOptions)
9c2abceb05c5 brightness min- and max- values scale with contrast settings (not yet for rgb).
robcast
parents: 1076
diff changeset
79 var maxBrgt = Math.max(Math.round(255 * Math.pow(2, data.settings.cont)), 255);
9c2abceb05c5 brightness min- and max- values scale with contrast settings (not yet for rgb).
robcast
parents: 1076
diff changeset
80 sliderOptions.brgt.min = -maxBrgt;
9c2abceb05c5 brightness min- and max- values scale with contrast settings (not yet for rgb).
robcast
parents: 1076
diff changeset
81 sliderOptions.brgt.max = maxBrgt;
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
82 var onChange = function($slider, val) {
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
83 colorVals['brgt'] = parseFloat(val);
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
84 updatePreview($slider);
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
85 };
1061
4f5c5c578aa4 rgb slider: color indicator functional, reset works only partially
hertzhaft
parents: 1060
diff changeset
86 var onSubmit = function(val) {
1042
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
87 digilib.actions.brightness(data, val);
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
88 };
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
89 singleSlider(data, 'brgt', onChange, onSubmit);
1042
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
90 },
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
91
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
92 // shows contrast slider
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
93 sliderCont : function (data) {
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
94 var onChange = function($slider, val) {
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
95 var m = Math.pow(2, parseFloat(val));
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
96 colorVals['cont'] = val;
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
97 colorVals['brgt'] = 127 - (127 * m);
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
98 updatePreview($slider);
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
99 };
1061
4f5c5c578aa4 rgb slider: color indicator functional, reset works only partially
hertzhaft
parents: 1060
diff changeset
100 var onSubmit = function(val) {
1042
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
101 digilib.actions.contrast(data, val, true);
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
102 };
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
103 singleSlider(data, 'cont', onChange, onSubmit);
1042
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
104 },
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
105
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
106 // shows rotate slider
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
107 sliderRot : function (data) {
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
108 var onChange = null;
1061
4f5c5c578aa4 rgb slider: color indicator functional, reset works only partially
hertzhaft
parents: 1060
diff changeset
109 var onSubmit = function(val) {
1042
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
110 digilib.actions.rotate(data, val);
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
111 };
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
112 singleSlider(data, 'rot', onChange, onSubmit);
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
113 },
1022
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
114
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
115 // shows RGB sliders
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
116 sliderRGB : function (data) {
1061
4f5c5c578aa4 rgb slider: color indicator functional, reset works only partially
hertzhaft
parents: 1060
diff changeset
117 var onSubmit = function(m, a) {
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
118 digilib.actions.setRGB(data, m, a);
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
119 };
1061
4f5c5c578aa4 rgb slider: color indicator functional, reset works only partially
hertzhaft
parents: 1060
diff changeset
120 rgbSlider(data, onSubmit);
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
121 }
1022
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
122 };
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
123
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
124 // update preview values for a given slider
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
125 var updatePreview = function ($slider) {
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
126 if ($slider == null) return;
1066
555f6f0d6be5 prepare for making rgb indicator an independent widget
hertzhaft
parents: 1065
diff changeset
127 var cls = $slider.data('cls');
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
128 var $preview = $slider.data('preview');
1079
9c2abceb05c5 brightness min- and max- values scale with contrast settings (not yet for rgb).
robcast
parents: 1076
diff changeset
129 if ($preview == null) {
9c2abceb05c5 brightness min- and max- values scale with contrast settings (not yet for rgb).
robcast
parents: 1076
diff changeset
130 console.error("slider updatePreview without preview!");
9c2abceb05c5 brightness min- and max- values scale with contrast settings (not yet for rgb).
robcast
parents: 1076
diff changeset
131 return;
9c2abceb05c5 brightness min- and max- values scale with contrast settings (not yet for rgb).
robcast
parents: 1076
diff changeset
132 }
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
133 var $td2 = $preview.find('table.'+cls+'preview td');
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
134 // account for current brgt/cont/rgbm/rgba values
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
135 var calcRGBValue = function (code, val) {
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
136 var c = colorVals[code];
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
137 var cm = Math.pow(2, c.m) * val;
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
138 var colorVal = cm + c.a;
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
139 var cont = Math.pow(2, colorVals.cont) * colorVal;
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
140 var brgt = colorVals.brgt;
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
141 var resultVal = cont + brgt;
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
142 return Math.min(Math.max(Math.round(resultVal), 0), 255);
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
143 };
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
144 // color one table cell according to index position
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
145 var setRGBValues = function (index) {
1066
555f6f0d6be5 prepare for making rgb indicator an independent widget
hertzhaft
parents: 1065
diff changeset
146 var val = index * 32;
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
147 var r = calcRGBValue('r', val);
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
148 var g = calcRGBValue('g', val);
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
149 var b = calcRGBValue('b', val);
1066
555f6f0d6be5 prepare for making rgb indicator an independent widget
hertzhaft
parents: 1065
diff changeset
150 $(this).css('background-color', 'rgb('+r+','+g+','+b+')');
555f6f0d6be5 prepare for making rgb indicator an independent widget
hertzhaft
parents: 1065
diff changeset
151 };
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
152 $td2.each(setRGBValues);
1066
555f6f0d6be5 prepare for making rgb indicator an independent widget
hertzhaft
parents: 1065
diff changeset
153 };
555f6f0d6be5 prepare for making rgb indicator an independent widget
hertzhaft
parents: 1065
diff changeset
154
1045
6329b7f8d7f8 method for reassigning a button
hertzhaft
parents: 1044
diff changeset
155 // assign button actions to sliders (rotate, brightness, contrast)
6329b7f8d7f8 method for reassigning a button
hertzhaft
parents: 1044
diff changeset
156 var setButtonActions = function () {
6329b7f8d7f8 method for reassigning a button
hertzhaft
parents: 1044
diff changeset
157 if (fn.setButtonAction == null) {
6329b7f8d7f8 method for reassigning a button
hertzhaft
parents: 1044
diff changeset
158 console.debug('sliders: could not assign button actions. Maybe jquery.digilib.buttons.js was not loaded?');
1022
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
159 return;
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
160 }
1045
6329b7f8d7f8 method for reassigning a button
hertzhaft
parents: 1044
diff changeset
161 console.debug('sliders: assign new button actions. digilib:', digilib);
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
162 fn.setButtonAction('brgt', 'sliderBrgt');
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
163 fn.setButtonAction('cont', 'sliderCont');
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
164 fn.setButtonAction('rot', 'sliderRot');
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
165 fn.setButtonAction('rgb', 'sliderRGB');
1022
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
166 };
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
167
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
168 // plugin installation called by digilib on plugin object.
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
169 var install = function (plugin) {
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
170 digilib = plugin;
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
171 console.debug('installing sliders plugin. digilib:', digilib);
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
172 fn = digilib.fn;
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
173 // import geometry classes
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
174 geom = fn.geometry;
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
175 // add defaults, actions, buttons
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
176 $.extend(true, digilib.defaults, defaults); // make deep copy
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
177 $.extend(digilib.actions, actions);
1038
a79be2432eb4 put new slider code back into sliders plugin
hertzhaft
parents: 1029
diff changeset
178 setButtonActions(digilib.buttons);
1022
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
179 // export functions
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
180 };
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
181
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
182 // plugin initialization
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
183 var init = function (data) {
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
184 console.debug('initialising sliders plugin. data:', data);
1058
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
185 var $data = $(data);
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
186 $data.bind('update', handleUpdate);
1022
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
187 };
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
188
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
189 // get brgt/cont/rgba/rgbm params (brightness/contrast/color)
1058
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
190 var handleUpdate = function (evt) {
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
191 console.debug("sliders: handleUpdate");
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
192 var data = this;
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
193 var settings = data.settings;
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
194 colorVals.brgt = parseFloat(settings.brgt) || 0;
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
195 colorVals.cont = parseFloat(settings.cont) || 0;
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
196 setRGBcolorVals(data, 'a');
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
197 setRGBcolorVals(data, 'm');
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
198 var sliderSelector = '#'+ settings.cssPrefix + 'slider';
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
199 var $slider = fn.find(data, sliderSelector);
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
200 fn.centerOnScreen(data, $slider);
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
201 updatePreview($slider);
1058
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
202 };
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
203
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
204 // read rgb m/a parameters and set start values for sliders
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
205 var setRGBcolorVals = function (data, code) {
1065
897f0560af46 do a proper reset for rgbm/rgba
hertzhaft
parents: 1064
diff changeset
206 var colorparts = data.settings['rgb'+code] || '0/0/0';
1058
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
207 var values = colorparts.split("/");
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
208 colorVals.r[code] = parseFloat(values[0]) || 0;
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
209 colorVals.g[code] = parseFloat(values[1]) || 0;
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
210 colorVals.b[code] = parseFloat(values[2]) || 0;
1058
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
211 };
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
212
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
213 /** creates a div with a form, setup events and callback
1022
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
214 */
1061
4f5c5c578aa4 rgb slider: color indicator functional, reset works only partially
hertzhaft
parents: 1060
diff changeset
215 var setupFormDiv = function (data, $content, cssSuffix, onSubmit) {
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
216 var cssPrefix = data.settings.cssPrefix;
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
217 var cls = cssPrefix + cssSuffix;
1062
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
218 var tiny = cssPrefix + 'tinyslider';
1058
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
219 var $elem = data.$elem;
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
220 var sliderSelector = '#'+cssPrefix+'slider';
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
221 if (fn.isOnScreen(data, sliderSelector)) return; // already onscreen
1026
01ea28b6fe11 commit sliders, not yet functional
hertzhaft
parents: 1022
diff changeset
222 var html = '\
1058
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
223 <div id="'+cssPrefix+'slider" class="'+cls+'">\
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
224 <form class="'+cls+'">\
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
225 <input class="'+cls+'cancel" type="button" value="Cancel"/>\
1062
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
226 <input class="'+cls+'reset" type="button" value="Reset"/>\
1071
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
227 <input class="'+cls+'default" type="button" value="Default"/>\
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
228 <input type="submit" name="sub" value="Ok"/>\
1042
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
229 </form>\
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
230 </div>';
1058
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
231 $div = $(html).appendTo($elem);
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
232 var $form = $div.find('form');
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
233 $form.prepend($content);
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
234 // handle submit
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
235 $form.on('submit', function () {
1061
4f5c5c578aa4 rgb slider: color indicator functional, reset works only partially
hertzhaft
parents: 1060
diff changeset
236 onSubmit();
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
237 fn.withdraw($div);
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
238 return false;
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
239 });
1062
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
240 // handle reset
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
241 $form.find('.'+cls+'reset').on('click', function () {
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
242 var sliders = $form.find('div.'+tiny);
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
243 sliders.each(function () {
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
244 var reset = $(this).data('reset');
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
245 reset();
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
246 });
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
247 });
1071
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
248 // handle default
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
249 $form.find('.'+cls+'default').on('click', function () {
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
250 var sliders = $form.find('div.'+tiny);
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
251 sliders.each(function () {
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
252 var reset = $(this).data('default');
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
253 reset();
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
254 });
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
255 });
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
256 // handle cancel
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
257 $form.find('.'+cls+'cancel').on('click', function () {
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
258 fn.withdraw($div);
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
259 });
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
260 // show div
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
261 $div.fadeIn();
1042
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
262 // fix non-HTML5 slider
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
263 var $range = $form.find('input.'+tiny+'range');
1042
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
264 var HTML5 = $range.prop('type') === 'range';
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
265 if (!HTML5) {
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
266 console.debug('fix input type=range');
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
267 $range.range({change: function (val) {
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
268 $range.trigger('change');
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
269 }});
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
270 }
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
271 fn.centerOnScreen(data, $div);
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
272 return $div;
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
273 };
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
274
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
275 /** creates a TinyRange slider
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
276 */
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
277 var tinySlider = function (data, paramname, startvalue) {
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
278 var $elem = data.$elem;
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
279 var opts = sliderOptions[paramname];
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
280 var cssPrefix = data.settings.cssPrefix;
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
281 var cls = cssPrefix + 'tinyslider';
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
282 var html = '\
1062
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
283 <div class="'+cls+'">\
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
284 <span>'+opts.label+'</span>\
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
285 <input type="range" class="'+cls+'range" name="'+paramname+'" step="'+opts.step+'" min="'+opts.min+'" max="'+opts.max+'" value="'+startvalue+'"/>\
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
286 <input type="text" class="'+cls+'text" name="'+paramname+'" size="4" value="'+startvalue+'"/>\
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
287 </div>';
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
288 var $slider = $(html);
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
289 var $range = $slider.find('input.'+cls+'range');
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
290 var $text = $slider.find('input.'+cls+'text');
1062
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
291 var rangeChange = function () {
1058
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
292 // crop floating point imprecision
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
293 var val = parseFloat($range.val()).toFixed(4);
95d28c6ad018 rgb slider now gets/sets values, plus some refactoring
hertzhaft
parents: 1057
diff changeset
294 $text.val(parseFloat(val));
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
295 var update = $slider.data('update');
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
296 if ($.isFunction(update)) {
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
297 update($slider, val);
1061
4f5c5c578aa4 rgb slider: color indicator functional, reset works only partially
hertzhaft
parents: 1060
diff changeset
298 }
1062
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
299 };
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
300 var textChange = function () {
1042
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
301 var val = $text.val();
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
302 $range.val(val);
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
303 // val doesn't change the slider handle position in Tinyrange
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
304 // can't use a jQuery "valHook" here because input type is reported as "text" (???)
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
305 var HTML5 = $range.prop('type') === 'range';
1044
2d04f160ce09 move slider handle when a new value is entered
hertzhaft
parents: 1043
diff changeset
306 if (!HTML5) {
2d04f160ce09 move slider handle when a new value is entered
hertzhaft
parents: 1043
diff changeset
307 $range.range('set', val);
2d04f160ce09 move slider handle when a new value is entered
hertzhaft
parents: 1043
diff changeset
308 }
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
309 var update = $slider.data('update');
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
310 if ($.isFunction(update)) {
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
311 update($slider, val);
1061
4f5c5c578aa4 rgb slider: color indicator functional, reset works only partially
hertzhaft
parents: 1060
diff changeset
312 }
1062
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
313 };
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
314 var reset = function () {
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
315 $text.val(startvalue);
1062
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
316 textChange();
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
317 };
1071
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
318 var resetdefault = function () {
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
319 $text.val(opts.start);
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
320 textChange();
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
321 };
1062
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
322 // connect slider and input
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
323 $range.on('change', rangeChange);
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
324 $text.on('change', textChange);
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
325 $slider.data({
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
326 '$text' : $text,
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
327 '$range' : $range,
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
328 'reset' : reset,
1071
9e06a7bf2303 button for resetting sliders to default value
hertzhaft
parents: 1070
diff changeset
329 'default' : resetdefault,
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
330 'update' : null
1042
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
331 });
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
332 return $slider;
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
333 };
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
334
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
335 /** creates a single TinyRangeSlider for param "paramname",
1061
4f5c5c578aa4 rgb slider: color indicator functional, reset works only partially
hertzhaft
parents: 1060
diff changeset
336 the new value is passed to the "onSubmit" function.
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
337 */
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
338 var singleSlider = function (data, paramname, onChange, onSubmit) {
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
339 var classname = 'singleslider';
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
340 var $div = $('<div/>');
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
341 var opts = sliderOptions[paramname];
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
342 var startvalue = data.settings[paramname] || opts.start;
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
343 var $slider = tinySlider(data, paramname, startvalue);
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
344 var getValue = function () {
1061
4f5c5c578aa4 rgb slider: color indicator functional, reset works only partially
hertzhaft
parents: 1060
diff changeset
345 // get the new value and do something with it
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
346 var val = $slider.data('$text').val();
1061
4f5c5c578aa4 rgb slider: color indicator functional, reset works only partially
hertzhaft
parents: 1060
diff changeset
347 onSubmit(val);
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
348 };
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
349 $div.append($slider);
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
350 setupFormDiv(data, $div, classname, getValue);
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
351 var hasPreview = opts.preview;
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
352 if (hasPreview) {
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
353 var cls = data.settings.cssPrefix + classname;
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
354 var $preview = preview(cls);
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
355 $div.append($preview);
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
356 $slider.data({
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
357 'cls' : cls,
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
358 'preview' : $preview,
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
359 'update' : onChange
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
360 });
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
361 onChange($slider, startvalue);
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
362 }
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
363 };
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
364
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
365 /** creates a compound RGB slider
1061
4f5c5c578aa4 rgb slider: color indicator functional, reset works only partially
hertzhaft
parents: 1060
diff changeset
366 the new values are passed to the "onSubmit" function.
1057
d139f59a5f80 rgb slider functional, get/set values not yet
hertzhaft
parents: 1047
diff changeset
367 */
1061
4f5c5c578aa4 rgb slider: color indicator functional, reset works only partially
hertzhaft
parents: 1060
diff changeset
368 var rgbSlider = function (data, onSubmit) {
1059
c7fd2f239953 rgb slider: color labels, first step to color indicator
hertzhaft
parents: 1058
diff changeset
369 var css = data.settings.cssPrefix;
c7fd2f239953 rgb slider: color labels, first step to color indicator
hertzhaft
parents: 1058
diff changeset
370 var cls = css + 'rgbslider';
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
371 var $div = $('<div/>');
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
372 var $table = $('<table class="'+cls+'" />');
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
373 var $preview = preview(cls);
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
374 $div.append($table);
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
375 $div.append($preview);
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
376 // create slider rows for the 3 primary colors
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
377 var insertTableRow = function(index, value) {
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
378 var color = colorVals[value];
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
379 // start values are set in "handleSetup"
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
380 var $tr = $('<tr/>').appendTo($table);
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
381 var html = '\
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
382 <td class="'+css+'color '+css+value+'">\
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
383 <div>'+color.label+'</div>\
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
384 </td>';
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
385 $(html).appendTo($tr);
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
386 var $brgt = tinySlider(data, 'brgt', color.a);
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
387 var $cont = tinySlider(data, 'cont', color.m);
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
388 $table.data(value+'a', $brgt.data('$text'));
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
389 $table.data(value+'m', $cont.data('$text'));
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
390 $('<td class="'+css+'rgb"/>').append($brgt).appendTo($tr);
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
391 $('<td class="'+css+'rgb"/>').append($cont).appendTo($tr);
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
392 };
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
393 var onChange = function ($slider) {
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
394 // show effects of color brightness/contrast on a grey scale
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
395 var input = $table.data();
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
396 $.each(primaryColors, function (index, value) {
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
397 colorVals[value].a = parseFloat(input[value+'a'].val());
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
398 colorVals[value].m = parseFloat(input[value+'m'].val());
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
399 });
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
400 updatePreview($slider);
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
401 };
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
402 var submitSliderValues = function () {
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
403 // get values from sliders
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
404 var input = $table.data();
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
405 var rgba = input['ra'].val() + '/' + input['ga'].val() + '/' + input['ba'].val();
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
406 var rgbm = input['rm'].val() + '/' + input['gm'].val() + '/' + input['bm'].val();
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
407 onSubmit(rgbm, rgba);
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
408 };
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
409 $.each(primaryColors, insertTableRow);
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
410 setupFormDiv(data, $div, 'rgbslider', submitSliderValues);
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
411 // update callback is made known to each slider
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
412 var $sliders = $div.find('div.'+css+'tinyslider');
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
413 $sliders.data({
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
414 'cls' : cls,
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
415 'preview' : $preview,
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
416 'update' : onChange
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
417 });
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
418 onChange($sliders);
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
419 };
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
420
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
421 /** creates a new preview div with 2 x 9 cells in scaled grey values
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
422 */
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
423 var preview = function (cls) {
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
424 var td = new Array(10).join('<td/>');
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
425 var html = '\
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
426 <div class="'+cls+'preview">\
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
427 <table class="'+cls+'grey">\
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
428 <tr>'+td+'</tr>\
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
429 </table>\
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
430 <table class="'+cls+'preview">\
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
431 <tr>'+td+'</tr>\
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
432 </table>\
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
433 </div>';
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
434 var $div = $(html);
1070
27ee06879f14 finished slider preview
hertzhaft
parents: 1069
diff changeset
435 // creates a table with a series of scaled grey values
1061
4f5c5c578aa4 rgb slider: color indicator functional, reset works only partially
hertzhaft
parents: 1060
diff changeset
436 var setGreyScale = function (index) {
1059
c7fd2f239953 rgb slider: color labels, first step to color indicator
hertzhaft
parents: 1058
diff changeset
437 var val = index * 32;
c7fd2f239953 rgb slider: color labels, first step to color indicator
hertzhaft
parents: 1058
diff changeset
438 $(this).css('background-color', 'rgb('+val+','+val+','+val+')');
c7fd2f239953 rgb slider: color labels, first step to color indicator
hertzhaft
parents: 1058
diff changeset
439 };
1062
41991d1598f1 rgb slider: reset now functional, minor refactoring
hertzhaft
parents: 1061
diff changeset
440 $div.find('table.'+cls+'grey td').each(setGreyScale);
1063
fb4d550869c8 indicators for brgt/cont sliders
hertzhaft
parents: 1062
diff changeset
441 return $div;
1042
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
442 };
2c5a48a624c5 TinyRange sliders now work for brgt,cont,rot (not perfect)
hertzhaft
parents: 1039
diff changeset
443
1022
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
444 // plugin object with name and init
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
445 // shared objects filled by digilib on registration
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
446 var plugin = {
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
447 name : 'sliders',
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
448 install : install,
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
449 init : init,
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
450 buttons : {},
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
451 actions : {},
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
452 fn : {},
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
453 plugins : {}
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
454 };
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
455
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
456 if ($.fn.digilib == null) {
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
457 $.error("jquery.digilib.sliders must be loaded after jquery.digilib!");
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
458 } else {
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
459 $.fn.digilib('plugin', plugin);
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
460 }
a1bb909dfd38 adding sliders plugin, not yet functional again
hertzhaft
parents:
diff changeset
461 })(jQuery);