Cannonball: Difference between revisions
From JSXGraph Wiki
| A WASSERMANN (talk | contribs) No edit summary | A WASSERMANN (talk | contribs) No edit summary | ||
| (4 intermediate revisions by the same user not shown) | |||
| Line 13: | Line 13: | ||
|              fAngle = function () { |              fAngle = function () { | ||
|                  return Math.atan2(cp.Y()-rp.Y(),cp.X()-rp.X()); |                  return Math.atan2(cp.Y()-rp.Y(), cp.X()-rp.X()); | ||
|              }, |              }, | ||
| Line 35: | Line 35: | ||
|              shoot = function() { |              shoot = function() { | ||
|                cannonball.setAttribute({ |                cannonball.setAttribute({ | ||
|                    visible: false |                    visible: false | ||
| Line 43: | Line 42: | ||
|                }); |                }); | ||
|                cbanim.moveTo([cannonball.X(), cannonball.Y()]); |                cbanim.moveTo([cannonball.X(), cannonball.Y()]); | ||
|                cbanim.moveAlong(fAnim, animTime(), { |                cbanim.moveAlong(fAnim, animTime(), { | ||
|                  callback: function () { |                  callback: function () { | ||
| Line 49: | Line 47: | ||
|                  } |                  } | ||
|                }); |                }); | ||
|             }, | |||
|             resetFunc = function() { | |||
|               board.stopAllAnimation(); | |||
|               cbanim.setAttribute({visible: false}); | |||
|               cannonball.setAttribute({visible: true}); | |||
|              }; |              }; | ||
|          board.options.animationDelay = 50; |          board.options.animationDelay = 50; | ||
| Line 70: | Line 71: | ||
|          solution = board.create('plot', [fSolution, function () { return cannonball.X(); }, 20], {visible: true, doAdvancedPlot: false}); |          solution = board.create('plot', [fSolution, function () { return cannonball.X(); }, 20], {visible: true, doAdvancedPlot: false}); | ||
|          shootButton = board.create('button', [9, 9.5, 'Shoot', shoot]), | |||
|          resetButton = board.create('button', [11, 9.5, 'Reset', resetFunc]); | |||
| })(); | |||
| </jsxgraph> | </jsxgraph> | ||
| <source lang="javascript"> | <source lang="javascript"> | ||
|      (function () { | |||
|          var board = JXG.JSXGraph.initBoard(' |          var board = JXG.JSXGraph.initBoard('jxgbox', {boundingbox: [0, 10, 20, 0], showCopyright: false, showNavigation: false}), | ||
|              bottom = board.create('image', [' |              bottom = board.create('image', ['https://jsxgraph.uni-bayreuth.de/wiki/images/1/13/Cannon_bottom.png', [0, 0.3], [2, 1]], {layer: 1}), | ||
|              muzzle = board.create('image', [' |              muzzle = board.create('image', ['https://jsxgraph.uni-bayreuth.de/wiki/images/e/e4/Cannon_muzzle.png', [0, 1.05], [3, 0.75]], {layer: 0}), | ||
|              shootButton, | |||
|              resetButton, | |||
|              rot, rp, cp, cc, cannonball, cbanim, solution, velocity, |              rot, rp, cp, cc, cannonball, cbanim, solution, velocity, | ||
| Line 110: | Line 90: | ||
|              fAngle = function () { |              fAngle = function () { | ||
|                  return Math.atan2(cp.Y()-rp.Y(),cp.X()-rp.X()); |                  return Math.atan2(cp.Y()-rp.Y(), cp.X()-rp.X()); | ||
|              }, |              }, | ||
| Line 129: | Line 109: | ||
|                  return s; |                  return s; | ||
|             }, | |||
|             shoot = function() { | |||
|               cannonball.setAttribute({ | |||
|                   visible: false | |||
|               }); | |||
|               cbanim.setAttribute({ | |||
|                 visible: true | |||
|               }); | |||
|               cbanim.moveTo([cannonball.X(), cannonball.Y()]); | |||
|               cbanim.moveAlong(fAnim, animTime(), { | |||
|                 callback: function () { | |||
|                     // this is executed when the animation is finished | |||
|                 } | |||
|               }); | |||
|             }, | |||
|             resetFunc = function() { | |||
|               board.stopAllAnimation(); | |||
|               cbanim.setAttribute({visible: false}); | |||
|               cannonball.setAttribute({visible: true}); | |||
|              }; |              }; | ||
|          board.options.animationDelay = 50; |          board.options.animationDelay = 50; | ||
| Line 147: | Line 148: | ||
|          solution = board.create('plot', [fSolution, function () { return cannonball.X(); }, 20], {visible: true, doAdvancedPlot: false}); |          solution = board.create('plot', [fSolution, function () { return cannonball.X(); }, 20], {visible: true, doAdvancedPlot: false}); | ||
|          shootButton = board.create('button', [9, 9.5, 'Shoot', shoot]), | |||
|          resetButton = board.create('button', [11, 9.5, 'Reset', resetFunc]); | |||
| })(); | |||
| </source> | </source> | ||
| [[Category:Examples]] | [[Category:Examples]] | ||
| [[Category:Physics]] | [[Category:Physics]] | ||
Latest revision as of 14:49, 24 January 2023
     (function () {
        var board = JXG.JSXGraph.initBoard('jxgbox', {boundingbox: [0, 10, 20, 0], showCopyright: false, showNavigation: false}),
            bottom = board.create('image', ['https://jsxgraph.uni-bayreuth.de/wiki/images/1/13/Cannon_bottom.png', [0, 0.3], [2, 1]], {layer: 1}),
            muzzle = board.create('image', ['https://jsxgraph.uni-bayreuth.de/wiki/images/e/e4/Cannon_muzzle.png', [0, 1.05], [3, 0.75]], {layer: 0}),
            shootButton,
            resetButton,
            rot, rp, cp, cc, cannonball, cbanim, solution, velocity,
            animTime = function () {
                return 3000;
            },
            fAngle = function () {
                return Math.atan2(cp.Y()-rp.Y(), cp.X()-rp.X());
            },
            fSolution = function (x) {
                var b = fAngle(),
                    g = 9.81/2;
                return Math.tan(b)*(x - cannonball.X()) - g*(Math.pow((x - cannonball.X())/(velocity.Value()*Math.cos(b)), 2)) + cannonball.Y();
            },
            fAnim = function (t) {
                var i = Math.floor(solution.points.length*t/animTime())/*3 + 17*t/animTime()*/,
                    s = NaN;
                if (JXG.exists(solution.points[i]) && solution.points[i].usrCoords[2] > 0) {
                    s = solution.points[i].usrCoords.slice(1);
                }
                return s;
            },
            shoot = function() {
              cannonball.setAttribute({
                  visible: false
              });
              cbanim.setAttribute({
                visible: true
              });
              cbanim.moveTo([cannonball.X(), cannonball.Y()]);
              cbanim.moveAlong(fAnim, animTime(), {
                callback: function () {
                    // this is executed when the animation is finished
                }
              });
            },
            resetFunc = function() {
              board.stopAllAnimation();
              cbanim.setAttribute({visible: false});
              cannonball.setAttribute({visible: true});
            };
            
        board.options.animationDelay = 50;
        velocity = board.create('slider', [[1, 9.5], [6, 9.5], [0, 5, 15]], {name: 'Velocity'});
        cp = board.create('point', [1.4, 1.4], {fixed: true, visible: false});
        cc = board.create('circle', [cp, 1.25], {visible: false});
        rp = board.create('glider', [0, 1.4, cc], {withLabel: false, showInfobox: false, color: 'black'});
        rot = board.create('transform', [fAngle, cp], {type: 'rotate'});
        rot.bindTo(muzzle);
        cannonball = board.create('point', [3, 1.4], {size: 8, strokeColor: 'black', fillColor: 'gray', withLabel: false, fixed: true});
        cbanim = board.create('point', [3, 1.4], {size: 8, strokeColor: 'black', fillColor: 'gray', withLabel: false, fixed: true, visible: false});
        rot.bindTo(cannonball);
        solution = board.create('plot', [fSolution, function () { return cannonball.X(); }, 20], {visible: true, doAdvancedPlot: false});
        shootButton = board.create('button', [9, 9.5, 'Shoot', shoot]),
        resetButton = board.create('button', [11, 9.5, 'Reset', resetFunc]);
})();
