2013-03-13 63 views
2

我正在使用Raphael和流星,並遇到了問題。我通過使用var paper = Raphael("paper", 800, 600);創建了一個paper如果我把這個代碼放在一個渲染函數中,比如Template.board.rendered,我可以使用它。然而,即使從模板中調用它們,來自該模板的論文var顯然不能被其他函數訪問。我認爲我可以通過在Meteor.startup中創建論文來解決這個問題,但我仍然遇到同樣的問題。如何訪問流星中多種方法的拉斐爾紙張

例如,下面的代碼無法正常工作:

Pieces = new Meteor.Collection('pieces'); 

Meteor.startup(function() { 
    var paper = Raphael("paper", 800, 600); 
}); 

Template.board.rendered = function() { 
    // If I create the paper in here along with the contents of createGoban 
    // it works, but then I can't use it anywhere else... 
    // var paper = Raphael("paper", 800, 600); 

    createGoban(); 
}; 

var createGoban = function() { 
    // Create goban 
    // Based off of svg in public domain: http://commons.wikimedia.org/wiki/File:Blank_Go_board.svg 
    // Converted using http://readysetraphael.com/ 
    var rect_a = paper.rect(0, 0, 96, 96); 
    rect_a.attr({fill: '#DCB35C','stroke-width': '0','stroke-opacity': '1'}).data('id', 'rect_a'); 
    var path_b = paper.path("M2.9,93h90.2m-.2-5H3m0-5h90m0-5H3m0-5h90m0-5H3m0-5h90m0-5H3m0-5h90m0-5H3m0-5h90m0-5H3m0-5h90m0-5H3m0-5h90m0-5H3m0-5h90m0-5H3m-.1-5h90.2M3,3V93m5,0V3m5,0V93m5,0V3m5,0V93m5,0V3m5,0V93m5,0V3m5,0V93m5,0V3m5,0V93m5,0V3m5,0V93m5,0V3m5,0V93m5,0V3m5,0V93m5,0V3m5,0V93m5,0V3"); 
    path_b.attr({stroke: '#000',"stroke-width": '0.2',fill: 'none','stroke-opacity': '1'}).data('id', 'path_b'); 
    var path_c = paper.path("M18,78l0,0m30,0l0,0m30,0l0,0m0-30l0,0m-30,0l0,0m-30,0l0,0m0-30l0,0m30,0l0,0m30,0l0,0"); 
    path_c.attr({stroke: '#000',"stroke-width": '4',"stroke-linecap": 'round','stroke-opacity': '1','fill': '#000000'}).data('id', 'path_c'); 
    var goban = [rect_a, path_b, path_c]; 

    // Scale goban up since rsr outputs reduced size 
    for(var i = 0; i < goban.length; i++) { 
    goban[i].transform('S5,5,0,0'); 
    }; 
}; 

回答

3

你的代碼工作正常取出varstartup(),這使得全球paper後:

Meteor.startup(function() { 
    paper = Raphael("paper", 800, 600); 
}); 
+1

哇哦,這是這樣的我的一個愚蠢的錯誤。非常感謝! – cttlfsh 2013-03-13 10:53:05