<!DOCTYPE html>
<html lang="en">
<head>
    <title>3D intersection 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 intersection sampler</h1>

<!-- plane-plane -->

<h2>Plane–plane</h2>
<p>This template is based on the <a href="https://github.com/jsxgraph/jsxgraph/blob/main/examples/intersection_plane_plane.html">plane–plane intersection 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="plane-plane-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(
        'plane-plane-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,
            size: 5,
            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
        }
    );
}
</script>

<!-- plane-sphere -->

<h2>Plane–sphere</h2>
<p>This template is based on the <a href="https://github.com/jsxgraph/jsxgraph/blob/main/examples/intersection_plane_sphere.html">plane–sphere intersection 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="plane-sphere-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(
        'plane-sphere-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 plane
    let basePoint = view.create(
        'point3d',
        [4/3, 4/3, 4/3],
        {
            withLabel: false,
            strokeWidth: 1,
            size: 5,
            strokeColor: '#300060',
            fillColor: 'white',
            gradientSecondColor: '#5000a0',
            highlightStrokeColor: '#300060'
        }
    );
    let plane = 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 a sphere
    let center = view.create(
        'point3d',
        [1.5, 1.5, 1.5],
        {
            withLabel: false,
            size: 5,
            strokeWidth: 1,
            strokeColor: '#600030',
            fillColor: 'white',
            gradientSecondColor: '#a00050',
            highlightStrokeColor: '#600030'
        }
    );
    let sphere = view.create(
    'sphere3d',
        [center, 1],
        {
            strokeColor: '#0000ff',
            strokeOpacity: 0.5,
            gradient: 'radial',
            gradientSecondColor: '#0000ff',
            fillOpacity: 0.2,
        }
    );
    
    // create the circle where the plane and the sphere intersect
    let ixnCircle = view.create(
        'intersectioncircle3d',
        [plane, sphere],
        {
            strokeColor: 'black',
            strokeOpacity: 0.5
        }
    );
}
</script>

<!-- sphere-sphere -->

<h2>Sphere–sphere</h2>
<p>This template is based on the <a href="https://github.com/jsxgraph/jsxgraph/blob/main/examples/intersection_sphere_sphere.html">sphere–sphere intersection 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="sphere-sphere-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(
        'sphere-sphere-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 two centers
    let center1 = view.create(
        'point3d',
        [1, 1.5, 1.5],
        {
            withLabel: false,
            size: 5,
            strokeWidth: 1,
            strokeColor: '#600030',
            fillColor: 'white',
            gradientSecondColor: '#a00050',
            highlightStrokeColor: '#600030'
       }
    );
    let center2 = view.create(
        'point3d',
        [2, 1.5, 1.5],
        {
            withLabel: false,
            size: 5,
            strokeWidth: 1,
            strokeColor: '#600030',
            fillColor: 'white',
            gradientSecondColor: '#a00050',
            highlightStrokeColor: '#600030'
       }
    );
    
    // create two spheres
    let sphere1 = view.create(
        'sphere3d',
        [center1, 0.75],
        {
            strokeColor: '#0000ff',
            strokeOpacity: 0.5,
            fillColor: 'white',
            fillOpacity: 0.2,
            gradientSecondColor: '#0000ff'
        }
    );
    let sphere2 = view.create(
        'sphere3d',
        [center2, 0.75],
        {
            strokeColor: '#00ff80',
            strokeOpacity: 0.5,
            fillColor: 'white',
            fillOpacity: 0.2,
            gradientSecondColor: '#00ff80'
        }
    );

    // create the circle where the spheres intersect
    let ixnCircle = view.create(
        'intersectioncircle3d',
        [sphere1, sphere2],
        {
            strokeColor: 'black',
            strokeOpacity: 0.5
        }
    );
}
</script>

</body>
</html>