root/libcore/DragState.h

/* [<][>][^][v][top][bottom][index][help] */

INCLUDED FROM


// 
//   Copyright (C) 2005, 2006, 2007, 2008, 2009, 2010,
//   2011 Free Software Foundation, Inc
// 
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 3 of the License, or
// (at your option) any later version.
// 
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
// 
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA

#ifndef GNASH_DRAG_STATE_H
#define GNASH_DRAG_STATE_H

#include "SWFRect.h"
#include "DisplayObject.h"

// Forward declarations
namespace gnash {
    class DisplayObject;
}

namespace gnash {

/// What is being dragged and how
class DragState
{
public:

    DragState(DisplayObject* d)
        :
        _hasbounds(false),
        _bounds(),
        _displayObject(d),
        _lock_centered(false)
    {
    }

    bool isLockCentered() const {
        return _lock_centered;
    }

    void setLockCentered(bool lock) {
        _lock_centered = lock;
    }

    /// Set displacement offset from origin
    /// at time of drag start.
    /// Coordinates are in stage space (twips)
    ///
    void setOffset(boost::int32_t x, boost::int32_t y) {
        _xoffset = x;
        _yoffset = y;
    }

    boost::int32_t xOffset() const { return _xoffset; }
    boost::int32_t yOffset() const { return _yoffset; }

    bool hasBounds() const {
        return _hasbounds;
    }

    /// \brief
    /// Get the boundaries to constraint
    /// the drag into.
    //
    /// Coordinates of the rectangle are
    /// expected in TWIPS.
    ///
    /// Note that if hasBounds() is false
    /// the returned rectangle is the NULL
    /// rectangle - see SWFRect::is_null().
    ///
    const SWFRect& getBounds() const { return _bounds; }

    /// \brief
    /// Set the boundaries to constraint
    /// the drag into.
    //
    /// Coordinates of the rectangle are
    /// expected in TWIPS.
    ///
    void setBounds(const SWFRect& bounds) {
        _bounds = bounds;
        _hasbounds = true;
    }

    /// May return NULL !!
    DisplayObject* getCharacter() const {
        return _displayObject;
    }

    /// Reset drag state to its initial condition
    void reset() {
        _displayObject = 0;
        _hasbounds = false;
        _bounds.set_null();
        _lock_centered = false;
    }

    /// Mark DisplayObject as reachable (if any)
    void markReachableResources() const {
        if (_displayObject) _displayObject->setReachable();
    }

private:

    bool _hasbounds;

    /// Boundaries to constrain the drag into.
    /// Coordinates in TWIPS.
    SWFRect _bounds;

    DisplayObject* _displayObject;

    bool _lock_centered;

    /// Offsets of displacement from DisplayObject origin
    /// at time of drag start. These are used for non
    /// lock-centered dragging.
    /// Coordinates are in stage space (TWIPS)
    boost::int32_t _xoffset;
    boost::int32_t _yoffset;

};


} // namespace gnash

#endif // GNASH_DRAG_STATE_H

/* [<][>][^][v][top][bottom][index][help] */