Czy ktoś mógłby mi to wyjaśnić?Wydaje się, że używam zmiennej przed jej pełnym utworzeniem w JavaScript, ale to działa - dlaczego?
var diagramImage = new Kinetic.Shape(function() {
var context = this.getContext();
context.beginPath();
context.lineWidth = 1;
//This is crazy tricks. It's part of the KineticJS demo website, but how am I able to assign diagramImage.color here?
context.strokeStyle = diagramImage.color;
var lastVertice = polygon.Vertices[polygon.Vertices.length - 1];
context.moveTo(lastVertice.X, lastVertice.Y);
for (var i = 0; i < polygon.Vertices.length; i++) {
var vertice = polygon.Vertices[i];
context.lineTo(vertice.X, vertice.Y);
}
context.stroke();
context.closePath();
});
Wydaje mi się, że nie istnieje diagramImage
aż kinetycznej powraca konstruktora, ale jestem w stanie (i wydaje się konieczne) przypisać strokeStyle
do diagramImage
„s kolor kontekst jest - przed diagramImage
został stworzony? Dlaczego to działa?
EDIT: Pełny kod:
function DrawPolygon(diagramLayer, polygon) {
var diagramImage = new Kinetic.Shape(function() {
var context = this.getContext();
context.beginPath();
context.lineWidth = 2;
//This is crazy tricks. It's part of the KineticJS demo website, but how am I able to assign diagramImage.color here?
context.strokeStyle = diagramImage.color;
var lastVertice = polygon.Vertices[polygon.Vertices.length - 1];
context.moveTo(lastVertice.X, lastVertice.Y);
for (var i = 0; i < polygon.Vertices.length; i++) {
var vertice = polygon.Vertices[i];
context.lineTo(vertice.X, vertice.Y);
}
context.stroke();
context.closePath();
});
diagramImage.color = "red";
diagramImage.on("mouseover", function() {
this.color = "green";
diagramLayer.draw();
});
diagramImage.on("mouseout", function() {
this.color = "red";
diagramLayer.draw();
});
diagramLayer.add(diagramImage);
planViewStage.add(diagramLayer);
}
Czy "diagramImage" jest już zdefiniowany przed tą częścią kodu, który zawiera? – ziesemer
Nie. Zobacz ten samouczek: http://www.html5canvastutorials.com/labs/html5-canvas-interactive-flower/ Robią to samo ze zmienną "center" –
Czy masz dodatkowy kod, który możesz opublikować, to dowodzi twoje twierdzenia? – shanabus