LoginSignup
1
0

More than 5 years have passed since last update.

CreateJsでオブジェクトを操作してみる(2)

Posted at

始めに

CreateJsで描画したオブジェクトのリサイズをやってみます

お試しサイト

https://afternoon-garden-70542.herokuapp.com/createjssample.html
にサンプルページをアップしています

感想

生Canvasを使ってコーディングするのに比べ、はるかに簡素なロジックでオブジェクトの操作が可能になります
すごいぜ、CreateJS!

ソース

sample.html
<html>
<head>
  <meta charset="utf-8" />
  <link rel="stylesheet" href="css/base.css" />
  <script src="https://code.createjs.com/1.0.0/createjs.min.js"></script>
  <script>
    //Canvasに対する各種イベント処理を管理するオブジェクト
    var myCanvasHander
    //Canvasに対する各種イベント処理の追加、削除を管理するオブジェクト定義します
    var sOpe  
    //オブジェクトのリサイズの可否を管理するフラグです
    var isResize = false
    //オブジェクトのリサイズ時に一度、イベントハンドラの処理を行ったら
    //それ以降イベントハンドラの追加処理を抑止するためのフラグです
    var isChangeEvent = false

    function MyCanvasHander(mystage){
        //CreateJsのStageオブジェクト
        var lstage = mystage
        var dragPointX
        var dragPointY
        var myshape
        var mouseclickflag
        var firstmove

        this.handleDown = function(e) {
            // ドラッグを開始した座標を覚えておく
            var rect = e.target.getBoundingClientRect();
            dragPointX = e.clientX - rect.left;
            dragPointY = e.clientY - rect.top;
            mouseclickflag =true
            firstmove = true;
        }
        this.handleMousemove = function(e){
            if(!mouseclickflag)return
            //mouseDownイベント後の初回のMoveイベント時は前のshapeは削除しない
            if(!firstmove && myshape && myshape.shape){
                lstage.removeChild(myshape.shape)
            }
            firstmove = false
            var rect = e.target.getBoundingClientRect();
            //四角形のオブジェクトを生成する
            myshape = new Rectengle(
                dragPointX,
                dragPointY,
                e.clientX - rect.left-dragPointX,
                e.clientY - rect.top-dragPointY,
                "Yellow")
            myshape.init(lstage)
            myshape.shape.alpha = 0.5;
        }
        this.handleMouseup = function(e){
            myshape.shape.alpha = 1.0;
            mouseclickflag =false
        }
    }

    function ShapeOperationToCanvas(myCanvasHander){
        //Canvasに対する各種イベントの定義を行います
        var funcs ={
            mousedown:{handleDown:myCanvasHander.handleDown},
            mousemove:{handleMousemove:myCanvasHander.handleMousemove},
            mouseup:{handleMouseup:myCanvasHander.handleMouseup}
        }
        //Canvasに対する各種イベントを追加します
        this.addOperation = function(){
            var canvas = document.getElementById('myCanvas');
            canvas.addEventListener('mousedown', funcs['mousedown']['handleDown'], false);
            canvas.addEventListener('mousemove', funcs['mousemove']['handleMousemove'], false);
            canvas.addEventListener('mouseup', funcs['mouseup']['handleMouseup'], false);
        }
        //Canvasに対する各種イベントを削除します
        this.removeOperation = function (){
            var canvas = document.getElementById('myCanvas');
            canvas.removeEventListener('mousedown', funcs['mousedown']['handleDown']);
            canvas.removeEventListener('mousemove', funcs['mousemove']['handleMousemove']);
            canvas.removeEventListener('mouseup', funcs['mouseup']['handleMouseup']);
        }
    }

    // ページの読み込みが終わってから初期化
    window.addEventListener("load", init);
    function init() {
        //Stageの生成とキャンバスに対する操作は
        //画面のロード完了後、実行する
        myCanvasHander= new MyCanvasHander(new createjs.Stage("myCanvas"))
        sOpe = new ShapeOperationToCanvas(myCanvasHander)
    }

    function Rectengle(start_x,start_y,end_x,end_y,color){
        this.width=end_x-start_x
        this.height=end_y-start_y
        this.color=color
        this.start_x=start_x
        this.start_y=start_y
        this.end_x=end_x
        this.end_y=end_y
        this.shape

        this.init = function(stage){
            // 初期化
            // 図形を作成
            this.shape = new createjs.Shape();
            stage.addChild(this.shape);
            this.shape.graphics.beginFill(color)
            .drawRect(this.start_x,this.start_y,this.end_x,this.end_y);
            // ドラッグした場所を保存する変数
            var dragPointX;
            var dragPointY;
            // インタラクティブの設定 drawShape
            this.shape.addEventListener("mousedown", handleDown);
            this.shape.addEventListener("pressmove", handleMove);
            this.shape.addEventListener("pressup", handleUp);
            stage.update()
            var _self = this;
            // 図形を押したときの処理です
            function handleDown(event) {
              sOpe.removeOperation()
              if(!isChangeEvent&&isResize){
                  _self.shape.addEventListener("pressmove", handleMoveOnResizing);
                  _self.shape.removeEventListener("pressmove", handleMove);
              }else if(!isResize){
                  _self.shape.addEventListener("pressmove", handleMove);
                  _self.shape.removeEventListener("pressmove", handleMoveOnResizing);
              }
              // ドラッグを開始した座標を覚えておく
              dragPointX = stage.mouseX - _self.shape.x;
              dragPointY = stage.mouseY - _self.shape.y;
              // ボールを半透明にする
              _self.shape.alpha = 0.3;
            }
            // 図形を押した状態で動かしたときの処理です(オブジェクトの移動)
            function handleMove(event) {
              // ボールはマウス座標に追随する
              // ただしドラッグ開始地点との補正をいれておく
              _self.shape.x = stage.mouseX - dragPointX;
              _self.shape.y = stage.mouseY - dragPointY;
            }
            // 図形を押した状態で動かしたときの処理です(オブジェクトのリサイズ)
            function handleMoveOnResizing(event) {
                //いったん、描画したオブジェクトを消す
                 _self.shape.graphics.clear().beginFill(_self.color)
                .drawRect(
                    _self.start_x,
                    _self.start_y,
                    stage.mouseX ,
                    stage.mouseY );
            }
            // ボールからマウスを離したときの処理です
            function handleUp(event) {
              // ボールを元の透明度に戻す
              _self.shape.alpha = 1.0;
            }
            // 時間経過
            createjs.Ticker.addEventListener("tick", handleTick);
            function handleTick() {
                stage.update(); // 画面更新
            }
        }

    }

  </script>
</head>
<body>
  <canvas id="myCanvas" width="500" height="300"></canvas><br>
  <input type = button  value = "図形追加 ON" onclick="sOpe.addOperation();isResize=false">
  <input type = button  value = "図形追加 OFF" onclick="sOpe.removeOperation();isResize=false">
  <input type = button  value = "図形リサイズ ON" onclick="isResize=true">
  <input type = button  value = "図形リサイズ OFF" onclick="isResize=false;isChangeEvent=false"><br>

  <h1 id="-">使い方</h1>
<ul>
<li>図形追加ボタン ONを押したとき<br>マウスの動きの合わせて図形が追加できます<br>この時、Cavasに追加オブジェクトを移動させたり、リサイズしたりはできません    </li>
<li>図形追加ボタン OFFを押したとき<br>図形追加モードが解除され、追加したイメージの移動ができるようになります    </li>
<li>図形リサイズON ボタンを押したとき<br>Canvasに追加したイメージをリサイズすることができます。<br>この時、イメージの移動はできません</li>
<li>図形リサイズOFFボタンを押したとき<br>Canvasに追加したイメージを移動できるようになります</li>
</ul>

</body>
</html>
1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0