Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
F
Front-End
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abdullh.alsoleman
Front-End
Commits
d2115a91
Commit
d2115a91
authored
Aug 03, 2015
by
Viktor Lidholt
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #437 from vlidholt/master
Refactors matrix handling in sprites
parents
a192280f
ed81aa6b
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
13 additions
and
10 deletions
+13
-10
node.dart
packages/flutter/example/game/lib/node.dart
+13
-10
No files found.
packages/flutter/example/game/lib/node.dart
View file @
d2115a91
...
@@ -102,7 +102,7 @@ class Node {
...
@@ -102,7 +102,7 @@ class Node {
void
set
rotation
(
double
rotation
)
{
void
set
rotation
(
double
rotation
)
{
assert
(
rotation
!=
null
);
assert
(
rotation
!=
null
);
_rotation
=
rotation
;
_rotation
=
rotation
;
_
invalidateTransformMatrix
();
invalidateTransformMatrix
();
}
}
/// The position of this node relative to its parent.
/// The position of this node relative to its parent.
...
@@ -113,7 +113,7 @@ class Node {
...
@@ -113,7 +113,7 @@ class Node {
void
set
position
(
Point
position
)
{
void
set
position
(
Point
position
)
{
assert
(
position
!=
null
);
assert
(
position
!=
null
);
_position
=
position
;
_position
=
position
;
_
invalidateTransformMatrix
();
invalidateTransformMatrix
();
}
}
/// The draw order of this node compared to its parent and its siblings.
/// The draw order of this node compared to its parent and its siblings.
...
@@ -147,7 +147,7 @@ class Node {
...
@@ -147,7 +147,7 @@ class Node {
void
set
scale
(
double
scale
)
{
void
set
scale
(
double
scale
)
{
assert
(
scale
!=
null
);
assert
(
scale
!=
null
);
_scaleX
=
_scaleY
=
scale
;
_scaleX
=
_scaleY
=
scale
;
_
invalidateTransformMatrix
();
invalidateTransformMatrix
();
}
}
/// The horizontal scale of this node relative its parent.
/// The horizontal scale of this node relative its parent.
...
@@ -158,7 +158,7 @@ class Node {
...
@@ -158,7 +158,7 @@ class Node {
void
set
scaleX
(
double
scaleX
)
{
void
set
scaleX
(
double
scaleX
)
{
assert
(
scaleX
!=
null
);
assert
(
scaleX
!=
null
);
_scaleX
=
scaleX
;
_scaleX
=
scaleX
;
_
invalidateTransformMatrix
();
invalidateTransformMatrix
();
}
}
/// The vertical scale of this node relative its parent.
/// The vertical scale of this node relative its parent.
...
@@ -169,7 +169,7 @@ class Node {
...
@@ -169,7 +169,7 @@ class Node {
void
set
scaleY
(
double
scaleY
)
{
void
set
scaleY
(
double
scaleY
)
{
assert
(
scaleY
!=
null
);
assert
(
scaleY
!=
null
);
_scaleY
=
scaleY
;
_scaleY
=
scaleY
;
_
invalidateTransformMatrix
();
invalidateTransformMatrix
();
}
}
/// A list of the children of this node.
/// A list of the children of this node.
...
@@ -264,10 +264,13 @@ class Node {
...
@@ -264,10 +264,13 @@ class Node {
///
///
/// Matrix4 matrix = myNode.transformMatrix;
/// Matrix4 matrix = myNode.transformMatrix;
Matrix4
get
transformMatrix
{
Matrix4
get
transformMatrix
{
if
(
_transformMatrix
!
=
null
)
{
if
(
_transformMatrix
=
=
null
)
{
return
_transformMatrix
;
_transformMatrix
=
computeTransformMatrix
()
;
}
}
return
_transformMatrix
;
}
Matrix4
computeTransformMatrix
()
{
double
cx
,
sx
,
cy
,
sy
;
double
cx
,
sx
,
cy
,
sy
;
if
(
_rotation
==
0.0
)
{
if
(
_rotation
==
0.0
)
{
...
@@ -287,15 +290,15 @@ class Node {
...
@@ -287,15 +290,15 @@ class Node {
}
}
// Create transformation matrix for scale, position and rotation
// Create transformation matrix for scale, position and rotation
_transformM
atrix
=
new
Matrix4
(
cy
*
_scaleX
,
sy
*
_scaleX
,
0.0
,
0.0
,
Matrix4
m
atrix
=
new
Matrix4
(
cy
*
_scaleX
,
sy
*
_scaleX
,
0.0
,
0.0
,
-
sx
*
_scaleY
,
cx
*
_scaleY
,
0.0
,
0.0
,
-
sx
*
_scaleY
,
cx
*
_scaleY
,
0.0
,
0.0
,
0.0
,
0.0
,
1.0
,
0.0
,
0.0
,
0.0
,
1.0
,
0.0
,
_position
.
x
,
_position
.
y
,
0.0
,
1.0
);
_position
.
x
,
_position
.
y
,
0.0
,
1.0
);
return
_transformM
atrix
;
return
m
atrix
;
}
}
void
_
invalidateTransformMatrix
()
{
void
invalidateTransformMatrix
()
{
_transformMatrix
=
null
;
_transformMatrix
=
null
;
_invalidateToBoxTransformMatrix
();
_invalidateToBoxTransformMatrix
();
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment