#ifndef HTMLImageElement_h
#define HTMLImageElement_h
#include "core/html/HTMLElement.h"
#include "core/html/HTMLImageLoader.h"
#include "core/html/canvas/CanvasImageSource.h"
#include "platform/graphics/GraphicsTypes.h"
#include "wtf/WeakPtr.h"
namespace WebCore {
class HTMLFormElement;
class HTMLImageElement FINAL : public HTMLElement, public CanvasImageSource {
public:
static PassRefPtr<HTMLImageElement> create(Document&);
static PassRefPtr<HTMLImageElement> create(Document&, HTMLFormElement*);
static PassRefPtr<HTMLImageElement> createForJSConstructor(Document&, int width, int height);
virtual ~HTMLImageElement();
int width(bool ignorePendingStylesheets = false);
int height(bool ignorePendingStylesheets = false);
int naturalWidth() const;
int naturalHeight() const;
bool isServerMap() const;
const AtomicString& altText() const;
CompositeOperator compositeOperator() const { return m_compositeOperator; }
ImageResource* cachedImage() const { return m_imageLoader.image(); }
void setImageResource(ImageResource* i) { m_imageLoader.setImage(i); };
void setLoadManually(bool loadManually) { m_imageLoader.setLoadManually(loadManually); }
const AtomicString& alt() const;
void setHeight(int);
KURL src() const;
void setSrc(const String&);
void setWidth(int);
int x() const;
int y() const;
bool complete() const;
bool hasPendingActivity() const { return m_imageLoader.hasPendingActivity(); }
virtual bool canContainRangeEndPoint() const OVERRIDE { return false; }
void addClient(ImageLoaderClient* client) { m_imageLoader.addClient(client); }
void removeClient(ImageLoaderClient* client) { m_imageLoader.removeClient(client); }
virtual const AtomicString imageSourceURL() const OVERRIDE;
virtual HTMLFormElement* formOwner() const OVERRIDE;
void formRemovedFromTree(const Node& formRoot);
virtual PassRefPtr<Image> getSourceImageForCanvas(SourceImageMode, SourceImageStatus*) const;
virtual bool wouldTaintOrigin(SecurityOrigin*) const OVERRIDE;
virtual FloatSize sourceSize() const OVERRIDE;
virtual FloatSize defaultDestinationSize() const OVERRIDE;
protected:
explicit HTMLImageElement(Document&, HTMLFormElement* = 0);
virtual void didMoveToNewDocument(Document& oldDocument) OVERRIDE;
private:
virtual bool areAuthorShadowsAllowed() const OVERRIDE { return false; }
virtual void parseAttribute(const QualifiedName&, const AtomicString&) OVERRIDE;
virtual bool isPresentationAttribute(const QualifiedName&) const OVERRIDE;
virtual void collectStyleForPresentationAttribute(const QualifiedName&, const AtomicString&, MutableStylePropertySet*) OVERRIDE;
virtual void attach(const AttachContext& = AttachContext()) OVERRIDE;
virtual RenderObject* createRenderer(RenderStyle*) OVERRIDE;
virtual bool canStartSelection() const OVERRIDE;
virtual bool isURLAttribute(const Attribute&) const OVERRIDE;
virtual bool hasLegalLinkAttribute(const QualifiedName&) const OVERRIDE;
virtual const QualifiedName& subResourceAttributeName() const OVERRIDE;
virtual bool draggable() const OVERRIDE;
virtual InsertionNotificationRequest insertedInto(ContainerNode*) OVERRIDE;
virtual void removedFrom(ContainerNode*) OVERRIDE;
virtual bool shouldRegisterAsNamedItem() const OVERRIDE { return true; }
virtual bool shouldRegisterAsExtraNamedItem() const OVERRIDE { return true; }
virtual bool isInteractiveContent() const OVERRIDE;
virtual Image* imageContents() OVERRIDE;
void resetFormOwner();
HTMLImageLoader m_imageLoader;
WeakPtr<HTMLFormElement> m_form;
CompositeOperator m_compositeOperator;
AtomicString m_bestFitImageURL;
float m_imageDevicePixelRatio;
bool m_formWasSetByParser;
};
}
#endif