前提・実現したいこと
javascriptのcreatejsにて、ボタンの作成でつまずきました。
var変数にコンテナを保存してそのコンテナに画像2つをaddchild、
addchildした画像の片方だけを非表示にしたいが、方法が分からず難儀している状態。
そもそもそういった非表示の指定は出来ないのか・・
ご存知の方がいらっしゃいましたらどうかご教授ください。
発生している問題・エラーメッセージ
firefox 61.0.2 のウェブ開発→デバッガ→コンソールには特にエラー表示無し
該当のソースコード
javascript
1<!DOCTYPE html> 2<head> 3 <meta charset="utf-8" /> 4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 5 <meta http-equiv="Content-Script-Type" content="text/javascript" /> 6 <meta http-equiv="Content-Style-Type" content="text/css" /> 7 <meta name="viewport" content="width=device-width, initial-scale=1"/> 8 <title></title> 9 <script type="text/javascript" src="js/createjs.min.js"></script> 10 <script type="text/javascript"> 11 window.addEventListener("load", main); 12 //処理 13 function main() { 14 var stage = new createjs.Stage("myCanvas"); 15 var test_btn1 = createButton("btn1"); 16 //var test_btn2 = createButton("btn2"); 17 test_btn1.x = 100; 18 test_btn1.y = 100; 19 stage.addChild(test_btn1); 20 init(); 21 22 //初期化 23 function init(){ 24 //ここでtest_btn1のbgUp(もしくはbgOut)のvisibleを非表示にしたいが指定方法が分からない 25 //test_btn1.button.bgUp.visible = false; では動作しなかった 26 //test_btn1.visible = false; だとbgUpとbgOut両方とも消えてしまう 27 //任意のタイミングで非表示にしたいので説明用にここを使用しています 28 } 29 30 //ボタン生成 31 function createButton(btnid) { 32 var button = new createjs.Container(); 33 button.name = btnid; 34 35 //アップ 36 var bgUp = new createjs.Bitmap("test_btn_up.png"); 37 bgUp.visible = false; 38 button.addChild(bgUp); 39 button.addEventListener("click", handleMouseUp); 40 41 //アウト 42 var bgOut = new createjs.Bitmap("test_btn_out.png"); 43 button.addChild(bgOut); 44 bgOut.visible = true; 45 46 //イベント 47 function handleMouseUp(event) { 48 pushitem = button.name; 49 /* 50 switch(pushitem){ 51 //ボタン名でそれぞれ処理 52 } 53 */ 54 //トグル 55 if(bgOut.visible){ 56 bgOut.visible = false; 57 bgUp.visible = true; 58 } 59 else if(bgUp.visible){ 60 bgOut.visible = true; 61 bgUp.visible = false; 62 } 63 } 64 return button; 65 } 66 //フレーム 67 createjs.Ticker.on("tick", function () { 68 stage.update(); 69 }); 70 } 71 </script> 72</head> 73<body> 74 <canvas id="myCanvas" width="2048" height="1536" style="width: 1024px; height: 768px"></canvas> 75</body> 76</html>
試したこと
test_btn1.button.bgUp.visible = false;
test_btn1["button"]["bgUp"].visible = false;
など
補足情報(FW/ツールのバージョンなど)
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。