在动力学js中重用画布代码

时间:2013-09-23 08:39:27

标签: javascript user-interface canvas widget kineticjs

我是JavaScript和KineticJS的新手,我正在开发GUI。 我用画布绘制了我需要的所有小部件,但我不知道如何在动力学的形状中重复使用它。 有没有办法将帆布的形状变成动力学的形状?

RenderCore.drawButton = function( w ){
ctx.beginPath();
var oldAlpha = ctx.globalAlpha;
ctx.globalAlpha = ctx.globalAlpha * w["fill-opacity"];

if ( w["rc"] != "0" )
{
    var rc = parseInt( w["rc"] );
    RenderCore._roundRect( w["x_abs"], w["y_abs"], w["w"], w["h"], w["rc"] );
}
else
{
    ctx.rect(w["x_abs"], w["y_abs"], w["w"], w["h"]);       
}

var fill = parseBool(w["pressed"]) ? w["pressed-fill"] : w["unpressed-fill"];
ctx.fillStyle = RenderCore._instantiateFillStyle( fill, w );
ctx.closePath();
ctx.fill();

ctx.globalAlpha = oldAlpha;

if ( w["stroke-width"] != "0")
{   
    ctx.lineWidth = w["stroke-width"];
    ctx.strokeStyle = w["stroke"];
    ctx.stroke();
}

// draw text
if ( w["unpressed-img"] == "" )
{
    ctx.font      = RenderCore._getFontStyle( w );
    ctx.fillStyle = w["font-color"];

    var len = ctx.measureText(w["text"]).width;
    var offset = (w["w"] - len) / 2;
    var text_y = (w["h"] / 2);

    ctx.textBaseline = "middle";
    ctx.fillText(w["text"], w["x_abs"] + offset, w["y_abs"] + text_y);
}
// draw image
else
{
    if ( w["text"] == "" )
    {
        var img_file = parseBool(w["pressed"]) ? w["pressed-img"] : w["unpressed-img"] ;
        var offsetX = (w["w"] - w["h"] * 0.8) / 2;
        var offsetY = (w["h"] * 0.2) / 2;
        var img = RenderCore.imgCache[ img_file ];
        if ( isDef(img) )
            ctx.drawImage(img, w["x_abs"] + offsetX, w["y_abs"] + offsetY, w["h"] * 0.8, w["h"] * 0.8);
    }
    else
    {
        var img_file = parseBool(w["pressed"]) ? w["pressed-img"] : w["unpressed-img"] ;
        var img = RenderCore.imgCache[ img_file ];
        // draw icon
        var offsetX = (w["h"] * 0.2) / 2;
        var offsetY = (w["h"] * 0.2) / 2;
        ctx.drawImage(img, w["x_abs"] + offsetX, w["y_abs"] + offsetY, w["h"] * 0.8, w["h"] * 0.8);

        // draw text
        ctx.font      = RenderCore._getFontStyle( w );
        ctx.fillStyle = w["font-color"];

        var len = ctx.measureText(w["text"]).width;
        // center alignment
        var offset = (w["w"] - w["h"] - len) / 2  +  w["h"];
        // Right alignment
        //var offset = offsetX + w["h"];

        var text_y = (w["h"] / 2);
        ctx.textBaseline = "middle";
        ctx.fillText(w["text"], w["x_abs"] + offset, w["y_abs"] + text_y);
    }
}};

其中w是“Widget”类的对象,其中包含我要添加到窗口小部件的所有属性,如width,height,font-color,ecc。

1 个答案:

答案 0 :(得分:0)

您可以使用自定义Kinetic.Shape对象。

Shape对象将为您提供一个画布上下文,您可以使用它来绘制所有普通的画布图:drawImage,fillText等。