我是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。
答案 0 :(得分:0)
您可以使用自定义Kinetic.Shape
对象。
Shape对象将为您提供一个画布上下文,您可以使用它来绘制所有普通的画布图:drawImage,fillText等。