lundi 27 juin 2016

How to push variable change to active canvas draw

I am attempting to change a variable of a js array that draws onto canvas when a specific php session variable is set. The php is being ran in a separate div from the canvas element and js. The canvas and js are being ran from the main page and the php event occurs in a child element. I am currently using php to define the variable used in js and when a session is set I want it to update the variable to be displayed in the canvas.

Here is code from the parent page

<?php    $colorin = 'rgba(81, 180, 200, 0.5)';    ?>


<script>

'use strict';



var rn = function rn(min, max) {
    return Math.random() * (max - min) + min;
};
var ctx = iso.getContext('2d');

var _window = window;
var w = _window.innerWidth;
var h = _window.innerHeight;

var t = 10;
var arr = [];
var cn = 200;
var rad = 300;
var sp = rn(1, 5) / 10000;

iso.width = w;
iso.height = h;

while (~ ~ cn--) {
    var angle = rn(110, 359);

    arr = [].concat(arr, [{
        color: '<?php echo $colorin ?>',
        distortion: rn(15, 75),
        tmod: rn(5, 10),
        size: rn(15, 20),
        speed: 0.0005,
        angle: angle,
        lastPos: {
            x: w / 2,
            y: h / 2
        }
    }]);
}

var draw = function draw() {
    request = requestAnimationFrame(function () {
        return draw();
    });
    t++;

    ctx.globalCompositeOperation = 'source-over';
    ctx.fillStyle = 'rgba(0, 0, 0,.1)';
    ctx.fillRect(0, 0, w, h);

    var crad = rad * Math.sin(300);

    ctx.globalCompositeOperation = 'lighter';
    arr.forEach(function (el) {
        ctx.strokeStyle = el.color;
        ctx.lineWidth = el.size;
        ctx.beginPath();

        var lastPos = el.angle - el.speed;
        var x = w / 2 + (crad + el.distortion * Math.sin(t / el.tmod)) * Math.cos(el.angle * 180 / Math.PI);
        var y = h / 2 + (crad + el.distortion * Math.sin(t / el.tmod)) * Math.sin(el.angle * 180 / Math.PI);

        ctx.moveTo(el.lastPos.x, el.lastPos.y);
        ctx.lineTo(x, y);

        el.lastPos = { x: x, y: y };
        el.angle = (el.angle + 0.0005) % 359;
        ctx.stroke();
    });
};

var resize = function resize() {
    iso.width = w = window.innerWidth;
    iso.height = h = window.innerHeight;
};

var request = requestAnimationFrame(function () {
    return draw();
});
window.addEventListener('resize', function () {
    return resize();
});

</script>             

and here is the code from the page loaded into a div on the main page.

  <?php
    session_start();         

    if (isset($_SESSION['userid'])){
    $userid = $_SESSION['userid'];
   $colorin = 'rgba(81, 180, 200, 0.5)';    

    echo "
<script>
                 $("#loghold").hide();   
</script>       
            ";
    }else{ 

      $colorin = 'rgba(255, 255, 255, 0.5)';         



  };

      echo "  "; 



 ?>

I am unsure how to execute an update of the code since the div is updating but the parent page is obviously not. I want to update the running js without refreshing or reloading the whole page.

(when the main page is reloaded it does show the desired change)

Aucun commentaire:

Enregistrer un commentaire