forked from thomasxiii/photon
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdocs.html
237 lines (190 loc) · 8.97 KB
/
docs.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<meta property="twitter:account_id" content="30870167">
<title>Photon | CSS 3D Lighting Engine</title>
<script type="text/javascript" src="http://use.typekit.com/yoe8gdj.js"></script>
<script type="text/javascript">try{Typekit.load();}catch(e){}</script>
<link rel="stylesheet" href="css/reset.css">
<link rel="stylesheet" href="css/base.css">
<script type="text/javascript">
var _gaq = _gaq || [];
_gaq.push(['_setAccount', 'UA-12900000-8']);
_gaq.push(['_trackPageview']);
(function() {
var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
})();
</script>
</head>
<body>
<nav class="primary-menu">
<h1>Photon</h1>
<h2>CSS 3D lighting engine</h2>
<ul>
<li><a href="index.html">Examples</a></li>
<li><a href="docs.html" class="current">Documentation</a></li>
<li><a href="https://github.com/thomasxiii/photon">GitHub Project</a></li>
<li><a href="js/photon.min.js" class="download-btn">download</a></li>
</ul>
</nav>
<div class="attasi">
<a href="http://attasi.com"><img src="images/attasi-logo.png" alt="attasi.com" /></a>
<a href="http://attasi.com">tom giannattasio</a>
<a href="https://twitter.com/attasi">@attasi</a>
</div>
<article class="docs-wrapper">
<section>
<h3>Introduction</h3>
<p>Photon is a JavaScript library that adds simple lighting effects to DOM elements in 3D space. It's rather processor-intensive, so please use responsibly.</p>
<h4>Contribute</h4>
<p>If you'd like to help, please do so on <a href="https://github.com/thomasxiii/photon">GitHub</a> or chat me up on <a href="https://twitter.com/attasi">twitter</a>.</p>
</section>
<section>
<h3>Quick Start</h3>
<section>
<h4>Create a Light</h4>
<p>The <code>Light</code> object represents a point in 3D space from which faces are lit.</p>
<pre><code><span class="comment">// creates a light at x: 0, y: 0, z: 100</span>
<span class="var">var</span> light = <span class="keyword">new</span> Photon.Light();</code></pre>
</section>
<section>
<h4>Define Faces</h4>
<p><code>Face</code> objects specify which DOM elements should be shaded or tinted by the light.</p>
<pre><code><span class="comment">// create a face with a max shade of .5</span>
<span class="var">var</span> face = <span class="keyword">new</span> Photon.Face( <span class="keyword">$</span>(<span class="string">'.face-1'</span>)[0] );</code></pre>
</section>
<section>
<h4>Render</h4>
<p>Call the <code>render</code> method on your faces to shade or tint them based on their angle from the specified light.</p>
<pre><code><span class="comment">// shade face by its relation to light</span>
face.render(light, <span class="boolean">true</span>);</code></pre>
</section>
</section>
<section class="library">
<h3>Library Reference</h3>
<section>
<h4>Light</h4>
<dl>
<dt><code>Photon.Light( x = 0, y = 0, z = 100 )</code><br /><em>constructor</em></dt>
<dd><p>Creates a new <code>Light</code> object. The default coordinates position the light straight towards the viewport.</p></dd>
<dt><code>moveTo( x, y, z )</code><br /><em>method</em></dt>
<dd><p>Moves the light to a new set of coordinates.</p></dd>
</dl>
</section>
<section>
<h4>Face</h4>
<dl>
<dt><code>Photon.Face( element, maxShade = .5, maxTint = 0, isBackfaced = false )</code><br /><em>constructor</em></dt>
<dd>
<p>Creates a new <code>Face</code> object. By default, the light will subtly shade each element.</p>
<dl class="property-list">
<dt><code>element</code><em>:object</em></dt>
<dd>
<p>The DOM object to which shading should be applied.</p>
</dd>
<dt><code>maxShade</code><em>:float</em></dt>
<dd>
<p>The maximum amount of black that can be added to an element: 0–1.</p>
</dd>
<dt><code>maxTint</code><em>:float</em></dt>
<dd>
<p>The maximum amount of white that can be added to an element: 0–1.</p>
</dd>
<dt><code>isBackfaced</code><em>:boolean</em></dt>
<dd>
<p>Determines if the backface of the <code>element</code> should be shaded as if it were its own face. Rule of thumb: If the opposite side the <code>element</code> is visible, you probably want to set this to <code>true</code>.</p>
</dd>
</dl>
</dd>
<dt><code>render( light, getNewRotations, parentRotations )</code><br /><em>method</em></dt>
<dd>
<p>Shades or tints the element based on its angle relative to the <code>Light</code> object. Shades and tints are applied to an empty div within the element with a class of <code>photon-shader</code>.</p>
<dl class="property-list">
<dt><code>light</code> <em>:Light</em></dt>
<dd>The <code>Light</code> object to use to calculate shading or tinting.</dd>
<dt><code>getNewRotations</code> <em>:boolean</em></dt>
<dd>If <code>true</code>, a new rotation vector is calculated before shading is applied. Use this when the element's transform property has changed.</dd>
<dt><code>parentRotations</code> <em>:object</em></dt>
<dd>The parent object's rotations (x, y and z in radians). These are used primarily for <code>FaceGroup</code> objects.</dd>
</dl>
</dd>
<dt><code>setMaxShade( value )</code><br /><em>method</em></dt>
<dd>
<p>Sets the maximum shade value: 0–1.</p>
<dl class="property-list">
<dt><code>value</code> <em>:float</em></dt>
</dl>
</dd>
<dt><code>setMaxTint( value )</code><br /><em>method</em></dt>
<dd>
<p>Sets the maximum tint value: 0–1.</p>
<dl class="property-list">
<dt><code>value</code> <em>:float</em></dt>
</dl>
</dd>
</dl>
</section>
<section>
<h4>FaceGroup</h4>
<dl>
<dt><code>Photon.FaceGroup( parent, faces, maxShade = .5, maxTint = 0, isBackfaced = false )</code><br /><em>constructor</em></dt>
<dd>
<p>Creates a new <code>FaceGroup</code> object, which allows one call of <code>render</code> to shade multiple faces. It also calculates the rotations of nested elements (i.e., if the parent element is rotated, the calculated rotations of the elements within it will be adjusted accordingly).</p>
<dl class="property-list">
<dt><code>parent</code><em>:object</em></dt>
<dd>
<p>The DOM object containing the faces to be shaded. Note: this element, itself, will not be shaded.</p>
</dd>
<dt><code>faces</code><em>:array</em></dt>
<dd>
<p>An array of DOM elements within the <code>parent</code> object, which should be shaded.</p>
</dd>
<dt><code>maxShade</code><em>:float</em></dt>
<dd>
<p>The maximum amount of black that can be added to the faces: 0–1.</p>
</dd>
<dt><code>maxTint</code><em>:float</em></dt>
<dd>
<p>The maximum amount of white that can be added to the faces: 0–1.</p>
</dd>
<dt><code>isBackfaced</code><em>:boolean</em></dt>
<dd>
<p>Determines if the backface of the <code>faces</code> should be shaded as if it were its own face. Rule of thumb: If the opposite side the <code>element</code> is visible, you probably want to set this to <code>true</code>.</p>
</dd>
</dl>
</dd>
<dt><code>render( light, getNewGroupRotations, getNewFaceRotations )</code><br /><em>method</em></dt>
<dd>
<p>Shades or tints the element based on its angle relative to the <code>Light</code> object. Shades and tints are applied to an empty div within the element with a class of <code>photon-shader</code>.</p>
<dl class="property-list">
<dt><code>light</code> <em>:Light</em></dt>
<dd>The <code>Light</code> object to use to calculate shading or tinting.</dd>
<dt><code>getNewGroupRotations</code> <em>:boolean</em></dt>
<dd>If <code>true</code>, a new rotation vector is calculated for the <code>parent</code> element before shading is applied. The new vector will affect the rotations of all <code>faces</code>. Use this when the <code>parent</code>'s transform property has changed.</dd>
<dt><code>getNewFaceRotations</code> <em>:boolean</em></dt>
<dd>If <code>true</code>, new rotation vectors are calculated for all of the <code>faces</code>. Use this when the transform properties of the<code>faces</code> have changed.</dd>
</dl>
</dd>
<dt><code>setMaxShade( value )</code><br /><em>method</em></dt>
<dd>
<p>Sets the maximum shade value: 0–1.</p>
<dl class="property-list">
<dt><code>value</code> <em>:float</em></dt>
</dl>
</dd>
<dt><code>setMaxTint( value )</code><br /><em>method</em></dt>
<dd>
<p>Sets the maximum tint value: 0–1.</p>
<dl class="property-list">
<dt><code>value</code> <em>:float</em></dt>
</dl>
</dd>
</dl>
</section>
</section>
</article>
</body>
</html>