<!DOCTYPE html>
<html lang="en">
<head>
    <title>3D glider sampler</title>
    <meta charset="UTF-8" />
    <link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/npm/jsxgraph/distrib/jsxgraph.css" />
    <script type="text/javascript" charset="UTF-8" src="https://cdn.jsdelivr.net/npm/jsxgraph/distrib/jsxgraphcore.js"></script>
</head>
<body>

<a href="../">↩ Back to index</a>

<h1>3D glider sampler</h1>

<!-- line glider -->

<h2>Line glider</h2>
<p>The large point is a glider on the line segment defined by the two small points. This template is based on the <a href="https://github.com/jsxgraph/jsxgraph/blob/main/examples/line3d_glider.html"><code>Line3D</code> glider example</a> in the <a href="https://github.com/jsxgraph/jsxgraph/tree/main/examples">examples folder</a> included with the source code.</p>
<div id="line-glider-board" class="jxgbox" style="width:600px; height:600px"></div>

<script type="text/javascript">
// to prevent variable name conflicts, we define variables locally using `let`
// and put the code for each board in its own block
{
    // create a JSXGraph board and draw a 3D view on it
    let board = JXG.JSXGraph.initBoard(
        'line-glider-board',
        {
            boundingbox: [-8, 8, 8,-8],
            axis: false,
            showCopyright: false,
            showNavigation: false
        }
    );
    let view = board.create(
        'view3d',
        [[-4.5, -4.5], [9, 9],
        [[0, 3], [0, 3], [0, 3]]],
        {
            xPlaneRear: {fillOpacity: 0.2, gradient: null},
            yPlaneRear: {fillOpacity: 0.2, gradient: null},
            zPlaneRear: {fillOpacity: 0.2, gradient: null}
        }
    );

    // create a line
    let p1 = view.create(
        'point3d',
        [0.5, 0.5, 0.5],
        {
            withLabel: false,
            strokeWidth: 1,
            strokeColor: '#300060',
            fillColor: 'white',
            gradientSecondColor: '#5000a0',
            highlightStrokeColor: '#300060'
        }
    );
    let p2 = view.create(
        'point3d',
        [2.5, 2.5, 2.5],
        {
            withLabel: false,
            strokeWidth: 1,
            strokeColor: '#300060',
            fillColor: 'white',
            gradientSecondColor: '#5000a0',
            highlightStrokeColor: '#300060'
        }
    );
    let line = view.create('line3d', [p1, p2]);

    // create a glider on the line
    let glider = view.create(
        'point3d',
        [1.5, 1.5, 1.5, line],
        {
            withLabel: false,
            size: 5,
            strokeWidth: 1,
            strokeColor: '#900060',
            fillColor: 'white',
            gradientSecondColor: '#fe00a0',
            highlightStrokeColor: '#900060'
        }
    );
}
</script>

<!-- intersection line glider -->

<h2>Intersection line glider</h2>
<p>The large point is a glider on the line where the two planes intersect.</p>
<div id="intersection-line-glider-board" class="jxgbox" style="width:600px; height:600px"></div>

<script type="text/javascript">
// to prevent variable name conflicts, we define variables locally using `let`
// and put the code for each board in its own block
{
    // create a JSXGraph board and draw a 3D view on it
    let board = JXG.JSXGraph.initBoard(
        'intersection-line-glider-board',
        {
            boundingbox: [-8, 8, 8,-8],
            axis: false,
            showCopyright: false,
            showNavigation: false
        }
    );
    let view = board.create(
        'view3d',
        [[-4.5, -4.5], [9, 9],
        [[0, 3], [0, 3], [0, 3]]],
        {
            xPlaneRear: {fillOpacity: 0.2, gradient: null},
            yPlaneRear: {fillOpacity: 0.2, gradient: null},
            zPlaneRear: {fillOpacity: 0.2, gradient: null}
        }
    );
    
    // create a point and two planes passing though it
    let basePoint = view.create(
        'point3d',
        [1, 1, 1],
        {
            withLabel: false,
            strokeWidth: 1,
            strokeColor: '#300060',
            fillColor: 'white',
            gradientSecondColor: '#5000a0',
            highlightStrokeColor: '#300060'
        }
    );
    let planeHoriz = view.create(
        'plane3d',
        [basePoint, [1, 0, 0], [0, 1, 0]],
        {
            strokeWidth: 1,
            strokeColor: '#0000ff',
            strokeOpacity: 0.5,
            fillColor: '#0000ff',
            fillOpacity: 0.1,
            gradient: null
        }
    );
    let planeSloped = view.create(
        'plane3d',
        [basePoint, [-2, 1, 1], [1, -2, 1]],
        {
            strokeWidth: 1,
            strokeColor: '#00ff80',
            strokeOpacity: 0.5,
            fillColor: '#00ff80',
            fillOpacity: 0.1,
            gradient: null
        }
    );
    
    // create the line where the two planes intersect
    let intersectionLine = view.create(
        'intersectionline3d',
        [planeHoriz, planeSloped],
        {
            strokeOpacity: 0.5,
            highlightStrokeColor: 'black',
            highlightStrokeOpacity: 0.5
        }
    );
    
    // create a glider on the intersection line
    let intersectionLineGlider = view.create(
        'point3d',
        [1.5, 0.5, 1, intersectionLine],
        {
            withLabel: false,
            size: 5,
            strokeWidth: 1,
            strokeColor: '#900060',
            fillColor: 'white',
            gradientSecondColor: '#fe00a0',
            highlightStrokeColor: '#900060'
        }
    );
}
</script>

<!-- circle glider -->

<h2>Circle glider</h2>
<p>The point is a glider on the circle. This template is based on the <a href="https://github.com/jsxgraph/jsxgraph/blob/main/examples/circle3d_glider.html"><code>Circle3D</code> glider example</a> in the <a href="https://github.com/jsxgraph/jsxgraph/tree/main/examples">examples folder</a> included with the source code.</p>
<p>Right now, the glider gets caught on the point where the circle starts and ends. If you can overcome this limitation, try contributing some code!</p>
<div id="circle-glider-board" class="jxgbox" style="width:600px; height:600px"></div>

<script type="text/javascript">
// to prevent variable name conflicts, we define variables locally using `let`
// and put the code for each board in its own block
{
    // create a JSXGraph board and draw a 3D view on it
    let board = JXG.JSXGraph.initBoard(
        'circle-glider-board',
        {
            boundingbox: [-8, 8, 8,-8],
            axis: false,
            showCopyright: false,
            showNavigation: false
        }
    );
    let view = board.create(
        'view3d',
        [[-4.5, -4.5], [9, 9],
        [[0, 3], [0, 3], [0, 3]]],
        {
            xPlaneRear: {fillOpacity: 0.2, gradient: null},
            yPlaneRear: {fillOpacity: 0.2, gradient: null},
            zPlaneRear: {fillOpacity: 0.2, gradient: null}
        }
    );

    // create a circle
    let circle = view.create(
        'circle3d',
        [[1.5, 1.5, 1.5], [1, 1, 1], 1]
    );

    // create a glider on the circle
    let glider = view.create(
        'point3d',
        [2, 0.5, 0.5, circle],
        {
            withLabel: false,
            size: 5,
            strokeWidth: 1,
            strokeColor: '#900060',
            fillColor: 'white',
            gradientSecondColor: '#fe00a0',
            highlightStrokeColor: '#900060'
        }
    );
}
</script>

<!-- curve glider -->

<h2>Curve glider</h2>
<p>The point is a glider on the curve. This template is based on the <a href="https://github.com/jsxgraph/jsxgraph/blob/main/examples/curve3d_glider.html"><code>Curve3D</code> glider example</a> in the <a href="https://github.com/jsxgraph/jsxgraph/tree/main/examples">examples folder</a> included with the source code.</p>
<div id="curve-glider-board" class="jxgbox" style="width:600px; height:600px"></div>

<script type="text/javascript">
// to prevent variable name conflicts, we define variables locally using `let`
// and put the code for each board in its own block
{
    // create a JSXGraph board and draw a 3D view on it
    let board = JXG.JSXGraph.initBoard(
        'curve-glider-board',
        {
            boundingbox: [-8, 8, 8,-8],
            axis: false,
            showCopyright: false,
            showNavigation: false
        }
    );
    let view = board.create(
        'view3d',
        [[-4.5, -4.5], [9, 9],
        [[0, 3], [0, 3], [0, 3]]],
        {
            xPlaneRear: {fillOpacity: 0.2, gradient: null},
            yPlaneRear: {fillOpacity: 0.2, gradient: null},
            zPlaneRear: {fillOpacity: 0.2, gradient: null}
        }
    );

    // create a 3D curve
    let curve = view.create(
        'curve3d',
        [
            (t) => 2.5 + t*t*(-8 + t*t*8),
            (t) => 1.5 + t*(5 + t*t*(-20 + t*t*16)),
            (t) => 1.5 + t*(-3 + t*t*4),
            [-1, 1]
        ]
    );

    // create a gilder on the curve
    let glider = view.create(
        'point3d',
        [2.5, 1.5, 1.5, curve],
        {
            withLabel: false,
            size: 5,
            strokeWidth: 1,
            strokeColor: '#900060',
            fillColor: 'white',
            gradientSecondColor: '#fe00a0',
            highlightStrokeColor: '#900060'
        }
    );
}
</script>

<!-- parametric surface glider -->

<h2>Parametric surface glider</h2>
<p>The point is a glider on the parametric surface. This template is based on the <a href="https://github.com/jsxgraph/jsxgraph/blob/main/examples/parametricsurface3d_glider.html"><code>ParametricSurface3D</code> glider example</a> in the <a href="https://github.com/jsxgraph/jsxgraph/tree/main/examples">examples folder</a> included with the source code. Gliders on parametric surfaces have been available for a long time; this summer’s work just made their motion more intuitive by keeping them inside the surface’s parameter range.</p>
<div id="surface-glider-board" class="jxgbox" style="width:600px; height:600px"></div>

<script type="text/javascript">
// to prevent variable name conflicts, we define variables locally using `let`
// and put the code for each board in its own block
{
    // create a JSXGraph board and draw a 3D view on it
    let board = JXG.JSXGraph.initBoard(
        'surface-glider-board',
        {
            boundingbox: [-8, 8, 8,-8],
            axis: false,
            showCopyright: false,
            showNavigation: false
        }
    );
    let view = board.create(
        'view3d',
        [[-4.5, -4.5], [9, 9],
        [[0, 2], [0, 2], [0, 2]]],
        {
            xPlaneRear: {fillOpacity: 0.2, gradient: null},
            yPlaneRear: {fillOpacity: 0.2, gradient: null},
            zPlaneRear: {fillOpacity: 0.2, gradient: null}
        }
    );

    // create a parametric surface, based on a modified Hammer projection
    let rModHammer = (u, v) => Math.sin(u)*Math.cos(v) / Math.sqrt(1 + 3*Math.cos(u)*Math.cos(v));
    let zModHammer = (u, v) => Math.sin(v) / Math.sqrt(1 + 3*Math.cos(u)*Math.cos(v));
    let twistFn = (u) => Math.PI/2 * Math.tanh(2*u);
    let surface = view.create('parametricsurface3d', [
        (u, v) => 1 + Math.cos(twistFn(v)) * rModHammer(u, v),
        (u, v) => 1 + Math.sin(twistFn(v)) * rModHammer(u, v),
        (u, v) => 1 + zModHammer(u, v),
        [-Math.PI/3, Math.PI/3],
        [-Math.PI/2, Math.PI/2]
    ], {
        strokeColor: '#b080f0',
        stepsU: 40,
        stepsV: 60
    });

    // create a glider on the surface
    let glider = view.create(
        'point3d',
        [1, 1, 1, surface],
        {
            withLabel: false,
            size: 5,
            strokeWidth: 1,
            strokeColor: '#900060',
            fillColor: 'white',
            gradientSecondColor: '#fe00a0',
            highlightStrokeColor: '#900060'
       }
    );
}
</script>

</body>
</html>