Difference between revisions of "Ticks"
A WASSERMANN (talk | contribs) |
(→Remove ticks) |
||
Line 94: | Line 94: | ||
=Remove ticks= | =Remove ticks= | ||
− | You can remove all ticks attached to a line or an axis by calling the <tt>removeAllTicks()</tt> method of the line you want to have 'tickless'. | + | You can remove all ticks attached to a line or an axis by calling the <tt>removeAllTicks()</tt> method of the line you want to have 'tickless' or you can remove specific ticks by calling <tt>removeTicks</tt> method of the given line instance with the a reference to the ticks instance as a parameter:# |
+ | <source lang="javascript"> | ||
+ | var xaxis = board.createElement('line', [point1, point2]); | ||
+ | var ticks = board.createElement('ticks', [xaxis, [1.0, 2.0, 5.0]]); | ||
+ | xaxis.removeTicks(ticks); | ||
+ | </source> | ||
[[Category:Examples]] | [[Category:Examples]] |
Revision as of 14:29, 25 March 2009
Ticks are little indicators on an axis to mark special positions on that axis. In JSXGraph they come in mainly three flavors: Equidistant, functional and special ticks. Equidistant ticks are those with the same distance between each marker, the distance between two functional ticks is determined by a function taking the number i of the tick ([math]i \in \mathbb{Z}[/math]) and returning the distance between the (i-1)-th and the i-th tick. Equidistant and functional ticks are created all over the axis against what special ticks are only created once.
Create Ticks
Note: You can create ticks on any GeometryElement based on the Line-object such as Line and Axis. So every appearance of axis in the examples on this page can be replaced by line and vice versa.
Equidistant ticks
To construct equidistant ticks you just have to call createElement with type ticks and parents array with a line or axis in the first and a positive number describing the distance between two ticks in the second element:
brd1.createElement('ticks',[axis, 5]);
For example:
var brd1 = JXG.JSXGraph.initBoard('box1', {originX: 350, originY: 100, unitX: 40, unitY: 40});
var ax1 = brd1.createElement('line', [[0,0],[1,0]]);
brd1.createElement('ticks',[ax1, 5], {minorTicks:4, majorTickHeight:10, minorTickHeight:4});
You may notice that here are some ticks that have bigger height than other ticks. Those are called major ticks, the smaller ones are called minor ticks. Ticks like shown above are automatically constructed when creating an axis:
var brd2 = JXG.JSXGraph.initBoard('box2', {originX: 350, originY: 100, unitX: 40, unitY: 40});
var ax2 = brd2.createElement('axis', [[0,0],[1,0]]);
If you wish to use other than the default options for the ticks when creating an axis, you can do so. The attributes names are the same when creating ticks directly:
Attribute | Type | Effect |
---|---|---|
insertTicks | bool | Inserts ticks whenever the distance between two ticks is too big. |
majorTickHeight | positive integer | This is the height (in pixel) for major ticks. |
minorTickHeight | positive integer | This is the height (in pixel) for minor ticks. |
minorTicks | positive integer | minorTicks is the amount of minor ticks between two major ticks. |
drawZero | bool | If true, a tick at zero (the first point of the two defining the line) is drawn. |
drawLabels | bool | If true, labels showing the ticks position on the axis are drawn beneath every majorTick. |
strokeColor | HTML colorstring | Changes stroke color of the ticks |
strokeWidth | positive integer | Drawing width for ticks. |
There's just one special attribute for creating equidistant ticks together with their axis: ticksDistance determines the distance between two major ticks.
Note: These options are for axis creation only and are ignored when constructing lines!
Special ticks
Special ticks can't be constructed together with an axis and therefore have to be created directly. The only difference between creating equidistant and creating special ticks is the second element of the parents array. For special ticks you have to give an array of positions on the axis, where special ticks are to be drawn. You always need an array for this, even if there's only one special tick to draw:
var brd3 = JXG.JSXGraph.initBoard('box3', {originX: 350, originY: 100, unitX: 40, unitY: 40});
var ax3 = brd3.createElement('axis', [[0,0],[1,0]]);
brd3.createElement('ticks', [ax3, [3.5]], {strokeColor: '#00ff00'});
Or more than one special tick:
var brd4 = JXG.JSXGraph.initBoard('box4', {originX: 350, originY: 100, unitX: 40, unitY: 40});
var ax4 = brd4.createElement('axis', [[0,0],[1,0]]);
brd4.createElement('ticks', [ax4, [-4.33333, -1.5, 3.5, 4.321]], {strokeColor: '#00ff00', majorTickHeight: 15});
The possible attributes here are mostly the same as above when creating equidistant ticks:
Attribute | Type | Effect |
---|---|---|
majorTickHeight | positive integer | This is the height (in pixel) for all special ticks. |
drawLabels | bool | If true, labels showing the ticks position on the axis are drawn beneath every majorTick. |
strokeColor | HTML colorstring | Changes stroke color of the ticks |
strokeWidth | positive integer | Drawing width for ticks. |
Remove ticks
You can remove all ticks attached to a line or an axis by calling the removeAllTicks() method of the line you want to have 'tickless' or you can remove specific ticks by calling removeTicks method of the given line instance with the a reference to the ticks instance as a parameter:#
var xaxis = board.createElement('line', [point1, point2]);
var ticks = board.createElement('ticks', [xaxis, [1.0, 2.0, 5.0]]);
xaxis.removeTicks(ticks);