make Sprite accept Picture and frame

This commit is contained in:
faiface 2017-03-31 15:00:59 +02:00
parent 0b3cfac547
commit 1b32c1a04b
1 changed files with 25 additions and 19 deletions

View File

@ -2,21 +2,26 @@ package pixel
import "image/color" import "image/color"
// Sprite is a drawable Picture. It's anchored by the center of it's Picture. // Sprite is a drawable frame of a Picture. It's anchored by the center of it's Picture's frame.
//
// Frame specifies a rectangular portion of the Picture that will be drawn. For example, this
// creates a Sprite that draws the whole Picture:
//
// sprite := pixel.NewSprite(pic, pic.Bounds())
// //
// To achieve different anchoring, transformations and color masking, use SetMatrix and SetColorMask // To achieve different anchoring, transformations and color masking, use SetMatrix and SetColorMask
// methods. // methods.
type Sprite struct { type Sprite struct {
tri *TrianglesData tri *TrianglesData
bounds Rect frame Rect
d Drawer d Drawer
matrix Matrix matrix Matrix
mask NRGBA mask NRGBA
} }
// NewSprite creates a Sprite from the supplied Picture. // NewSprite creates a Sprite from the supplied frame of a Picture.
func NewSprite(pic Picture) *Sprite { func NewSprite(pic Picture, frame Rect) *Sprite {
tri := MakeTrianglesData(6) tri := MakeTrianglesData(6)
s := &Sprite{ s := &Sprite{
tri: tri, tri: tri,
@ -24,21 +29,17 @@ func NewSprite(pic Picture) *Sprite {
} }
s.matrix = IM s.matrix = IM
s.mask = NRGBA{1, 1, 1, 1} s.mask = NRGBA{1, 1, 1, 1}
s.SetPicture(pic) s.Set(pic, frame)
return s return s
} }
// SetPicture changes the Sprite's Picture. The new Picture may have a different size, everything // Set sets a new frame of a Picture for this Sprite.
// works. func (s *Sprite) Set(pic Picture, frame Rect) {
func (s *Sprite) SetPicture(pic Picture) {
s.d.Picture = pic s.d.Picture = pic
if frame != s.frame {
if s.bounds == pic.Bounds() { s.frame = frame
return s.calcData()
} }
s.bounds = pic.Bounds()
s.calcData()
} }
// Picture returns the current Sprite's Picture. // Picture returns the current Sprite's Picture.
@ -46,6 +47,11 @@ func (s *Sprite) Picture() Picture {
return s.d.Picture return s.d.Picture
} }
// Frame returns the current Sprite's frame.
func (s *Sprite) Frame() Rect {
return s.frame
}
// SetMatrix sets a Matrix that this Sprite will be transformed by. This overrides any previously // SetMatrix sets a Matrix that this Sprite will be transformed by. This overrides any previously
// set Matrix. // set Matrix.
// //
@ -83,9 +89,9 @@ func (s *Sprite) Draw(t Target) {
func (s *Sprite) calcData() { func (s *Sprite) calcData() {
var ( var (
center = s.bounds.Center() center = s.frame.Center()
horizontal = X(s.bounds.W() / 2) horizontal = X(s.frame.W() / 2)
vertical = Y(s.bounds.H() / 2) vertical = Y(s.frame.H() / 2)
) )
(*s.tri)[0].Position = -horizontal - vertical (*s.tri)[0].Position = -horizontal - vertical