2001-09-29 00:14:13 +04:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
2004-04-18 18:30:37 +04:00
|
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
1999-04-14 01:50:25 +04:00
|
|
|
*
|
2004-04-18 18:30:37 +04:00
|
|
|
* The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
|
|
* the License. You may obtain a copy of the License at
|
|
|
|
* http://www.mozilla.org/MPL/
|
1999-04-14 01:50:25 +04:00
|
|
|
*
|
2001-09-29 00:14:13 +04:00
|
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
* for the specific language governing rights and limitations under the
|
|
|
|
* License.
|
1999-04-14 01:50:25 +04:00
|
|
|
*
|
1999-11-06 06:40:37 +03:00
|
|
|
* The Original Code is mozilla.org code.
|
|
|
|
*
|
2004-04-18 18:30:37 +04:00
|
|
|
* The Initial Developer of the Original Code is
|
2001-09-29 00:14:13 +04:00
|
|
|
* Netscape Communications Corporation.
|
|
|
|
* Portions created by the Initial Developer are Copyright (C) 1998
|
|
|
|
* the Initial Developer. All Rights Reserved.
|
1999-11-06 06:40:37 +03:00
|
|
|
*
|
2001-09-29 00:14:13 +04:00
|
|
|
* Contributor(s):
|
|
|
|
*
|
|
|
|
* Alternatively, the contents of this file may be used under the terms of
|
2004-04-18 18:30:37 +04:00
|
|
|
* either of the GNU General Public License Version 2 or later (the "GPL"),
|
|
|
|
* or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
2001-09-29 00:14:13 +04:00
|
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
2004-04-18 18:30:37 +04:00
|
|
|
* use your version of this file under the terms of the MPL, indicate your
|
2001-09-29 00:14:13 +04:00
|
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
|
|
* the provisions above, a recipient may use your version of this file under
|
2004-04-18 18:30:37 +04:00
|
|
|
* the terms of any one of the MPL, the GPL or the LGPL.
|
2001-09-29 00:14:13 +04:00
|
|
|
*
|
|
|
|
* ***** END LICENSE BLOCK ***** */
|
2006-03-29 22:29:03 +04:00
|
|
|
|
|
|
|
/* rendering object for replaced elements with bitmap image data */
|
|
|
|
|
1999-04-14 01:50:25 +04:00
|
|
|
#ifndef nsImageFrame_h___
|
|
|
|
#define nsImageFrame_h___
|
|
|
|
|
2001-11-01 18:31:13 +03:00
|
|
|
#include "nsSplittableFrame.h"
|
1999-04-14 01:50:25 +04:00
|
|
|
#include "nsString.h"
|
2002-03-24 01:26:36 +03:00
|
|
|
#include "nsAString.h"
|
2004-08-01 03:15:21 +04:00
|
|
|
#include "nsPresContext.h"
|
2001-02-20 00:50:04 +03:00
|
|
|
#include "nsIImageFrame.h"
|
2004-01-21 12:35:59 +03:00
|
|
|
#include "nsIIOService.h"
|
2004-02-03 23:30:02 +03:00
|
|
|
#include "nsIObserver.h"
|
1999-04-14 01:50:25 +04:00
|
|
|
|
2001-03-22 04:38:35 +03:00
|
|
|
#include "nsTransform2D.h"
|
|
|
|
#include "imgIRequest.h"
|
2006-06-17 01:07:47 +04:00
|
|
|
#include "nsStubImageDecoderObserver.h"
|
2001-03-22 04:38:35 +03:00
|
|
|
|
1999-04-14 01:50:25 +04:00
|
|
|
class nsIFrame;
|
|
|
|
class nsImageMap;
|
1999-06-23 07:29:44 +04:00
|
|
|
class nsIURI;
|
2001-03-22 04:38:35 +03:00
|
|
|
class nsILoadGroup;
|
1999-04-14 01:50:25 +04:00
|
|
|
struct nsHTMLReflowState;
|
|
|
|
struct nsHTMLReflowMetrics;
|
|
|
|
struct nsSize;
|
2006-01-26 05:29:17 +03:00
|
|
|
class nsDisplayImage;
|
1999-04-14 01:50:25 +04:00
|
|
|
|
2001-03-22 04:38:35 +03:00
|
|
|
class nsImageFrame;
|
|
|
|
|
2006-06-17 01:07:47 +04:00
|
|
|
class nsImageListener : public nsStubImageDecoderObserver
|
2001-03-22 04:38:35 +03:00
|
|
|
{
|
|
|
|
public:
|
2001-04-15 06:13:49 +04:00
|
|
|
nsImageListener(nsImageFrame *aFrame);
|
2001-03-22 04:38:35 +03:00
|
|
|
virtual ~nsImageListener();
|
|
|
|
|
|
|
|
NS_DECL_ISUPPORTS
|
2006-06-17 01:07:47 +04:00
|
|
|
// imgIDecoderObserver (override nsStubImageDecoderObserver)
|
|
|
|
NS_IMETHOD OnStartContainer(imgIRequest *aRequest, imgIContainer *aImage);
|
|
|
|
NS_IMETHOD OnDataAvailable(imgIRequest *aRequest, gfxIImageFrame *aFrame,
|
|
|
|
const nsRect *aRect);
|
|
|
|
NS_IMETHOD OnStopDecode(imgIRequest *aRequest, nsresult status,
|
|
|
|
const PRUnichar *statusArg);
|
|
|
|
// imgIContainerObserver (override nsStubImageDecoderObserver)
|
|
|
|
NS_IMETHOD FrameChanged(imgIContainer *aContainer, gfxIImageFrame *newframe,
|
|
|
|
nsRect * dirtyRect);
|
2001-03-22 04:38:35 +03:00
|
|
|
|
|
|
|
void SetFrame(nsImageFrame *frame) { mFrame = frame; }
|
|
|
|
|
|
|
|
private:
|
|
|
|
nsImageFrame *mFrame;
|
|
|
|
};
|
|
|
|
|
2003-02-25 01:20:26 +03:00
|
|
|
#define IMAGE_SIZECONSTRAINED 0x00100000
|
|
|
|
#define IMAGE_GOTINITIALREFLOW 0x00200000
|
|
|
|
|
2001-11-01 18:31:13 +03:00
|
|
|
#define ImageFrameSuper nsSplittableFrame
|
1999-04-14 01:50:25 +04:00
|
|
|
|
2001-02-20 00:50:04 +03:00
|
|
|
class nsImageFrame : public ImageFrameSuper, public nsIImageFrame {
|
1999-04-14 01:50:25 +04:00
|
|
|
public:
|
2006-03-27 01:30:36 +04:00
|
|
|
nsImageFrame(nsStyleContext* aContext);
|
2000-04-19 18:00:11 +04:00
|
|
|
|
2001-02-20 00:50:04 +03:00
|
|
|
// nsISupports
|
|
|
|
NS_IMETHOD QueryInterface(const nsIID& aIID, void** aInstancePtr);
|
|
|
|
|
2006-04-10 04:16:29 +04:00
|
|
|
virtual void Destroy();
|
2006-03-09 21:55:21 +03:00
|
|
|
NS_IMETHOD Init(nsIContent* aContent,
|
1999-04-14 01:50:25 +04:00
|
|
|
nsIFrame* aParent,
|
|
|
|
nsIFrame* aPrevInFlow);
|
2006-01-26 05:29:17 +03:00
|
|
|
NS_IMETHOD BuildDisplayList(nsDisplayListBuilder* aBuilder,
|
|
|
|
const nsRect& aDirtyRect,
|
|
|
|
const nsDisplayListSet& aLists);
|
2004-08-01 03:15:21 +04:00
|
|
|
NS_IMETHOD Reflow(nsPresContext* aPresContext,
|
1999-04-14 01:50:25 +04:00
|
|
|
nsHTMLReflowMetrics& aDesiredSize,
|
|
|
|
const nsHTMLReflowState& aReflowState,
|
|
|
|
nsReflowStatus& aStatus);
|
2001-08-30 02:59:09 +04:00
|
|
|
|
2004-08-01 03:15:21 +04:00
|
|
|
NS_IMETHOD GetContentForEvent(nsPresContext* aPresContext,
|
2000-02-11 04:24:59 +03:00
|
|
|
nsEvent* aEvent,
|
|
|
|
nsIContent** aContent);
|
2004-08-01 03:15:21 +04:00
|
|
|
NS_IMETHOD HandleEvent(nsPresContext* aPresContext,
|
1999-04-14 01:50:25 +04:00
|
|
|
nsGUIEvent* aEvent,
|
1999-11-24 09:03:41 +03:00
|
|
|
nsEventStatus* aEventStatus);
|
2004-12-31 00:56:11 +03:00
|
|
|
NS_IMETHOD GetCursor(const nsPoint& aPoint,
|
|
|
|
nsIFrame::Cursor& aCursor);
|
2005-09-07 20:49:21 +04:00
|
|
|
NS_IMETHOD AttributeChanged(PRInt32 aNameSpaceID,
|
1999-04-14 01:50:25 +04:00
|
|
|
nsIAtom* aAttribute,
|
2003-07-12 01:16:12 +04:00
|
|
|
PRInt32 aModType);
|
2001-05-18 03:52:32 +04:00
|
|
|
|
2001-08-17 07:13:07 +04:00
|
|
|
#ifdef ACCESSIBILITY
|
2001-05-18 03:52:32 +04:00
|
|
|
NS_IMETHOD GetAccessible(nsIAccessible** aAccessible);
|
2001-08-17 07:13:07 +04:00
|
|
|
#endif
|
2001-05-18 03:52:32 +04:00
|
|
|
|
2003-10-31 23:19:18 +03:00
|
|
|
virtual nsIAtom* GetType() const;
|
2001-10-31 07:43:48 +03:00
|
|
|
#ifdef DEBUG
|
2005-05-09 21:46:06 +04:00
|
|
|
NS_IMETHOD GetFrameName(nsAString& aResult) const;
|
2005-09-07 01:34:50 +04:00
|
|
|
NS_IMETHOD List(FILE* out, PRInt32 aIndent) const;
|
2001-10-31 07:43:48 +03:00
|
|
|
#endif
|
|
|
|
|
2004-08-01 03:15:21 +04:00
|
|
|
NS_IMETHOD GetImageMap(nsPresContext *aPresContext, nsIImageMap **aImageMap);
|
2002-08-17 05:46:58 +04:00
|
|
|
|
2000-01-04 06:06:13 +03:00
|
|
|
NS_IMETHOD GetIntrinsicImageSize(nsSize& aSize);
|
2000-09-09 02:52:05 +04:00
|
|
|
|
2004-02-03 23:30:02 +03:00
|
|
|
static void ReleaseGlobals() {
|
|
|
|
if (gIconLoad) {
|
|
|
|
gIconLoad->Shutdown();
|
|
|
|
NS_RELEASE(gIconLoad);
|
|
|
|
}
|
|
|
|
NS_IF_RELEASE(sIOService);
|
|
|
|
}
|
2004-01-21 12:35:59 +03:00
|
|
|
|
2005-09-18 22:05:40 +04:00
|
|
|
/**
|
|
|
|
* Function to test whether aContent, which has aStyleContext as its style,
|
|
|
|
* should get an image frame. Note that this method is only used by the
|
|
|
|
* frame constructor; it's only here because it uses gIconLoad for now.
|
|
|
|
*/
|
|
|
|
static PRBool ShouldCreateImageFrameFor(nsIContent* aContent,
|
|
|
|
nsStyleContext* aStyleContext);
|
|
|
|
|
2006-01-26 05:29:17 +03:00
|
|
|
void DisplayAltFeedback(nsIRenderingContext& aRenderingContext,
|
|
|
|
imgIRequest* aRequest,
|
|
|
|
nsPoint aPt);
|
|
|
|
|
|
|
|
nsRect GetInnerArea() const;
|
|
|
|
|
|
|
|
nsImageMap* GetImageMap(nsPresContext* aPresContext);
|
|
|
|
|
1999-04-14 01:50:25 +04:00
|
|
|
protected:
|
2001-02-20 00:50:04 +03:00
|
|
|
// nsISupports
|
|
|
|
NS_IMETHOD_(nsrefcnt) AddRef(void);
|
|
|
|
NS_IMETHOD_(nsrefcnt) Release(void);
|
|
|
|
|
1999-04-14 01:50:25 +04:00
|
|
|
virtual ~nsImageFrame();
|
|
|
|
|
2004-08-01 03:15:21 +04:00
|
|
|
virtual void GetDesiredSize(nsPresContext* aPresContext,
|
1999-04-14 01:50:25 +04:00
|
|
|
const nsHTMLReflowState& aReflowState,
|
|
|
|
nsHTMLReflowMetrics& aDesiredSize);
|
|
|
|
|
2004-08-01 03:15:21 +04:00
|
|
|
void TriggerLink(nsPresContext* aPresContext,
|
2002-11-20 03:44:26 +03:00
|
|
|
nsIURI* aURI,
|
1999-04-14 01:50:25 +04:00
|
|
|
const nsString& aTargetSpec,
|
2006-02-02 23:02:34 +03:00
|
|
|
nsINode* aTriggerNode,
|
1999-04-14 01:50:25 +04:00
|
|
|
PRBool aClick);
|
|
|
|
|
|
|
|
PRBool IsServerImageMap();
|
|
|
|
|
2004-12-26 22:48:54 +03:00
|
|
|
void TranslateEventCoords(const nsPoint& aPoint,
|
1999-07-08 23:38:08 +04:00
|
|
|
nsPoint& aResult);
|
|
|
|
|
2006-02-02 23:02:34 +03:00
|
|
|
PRBool GetAnchorHREFTargetAndNode(nsIURI** aHref, nsString& aTarget,
|
|
|
|
nsINode** aNode);
|
2006-07-31 11:08:45 +04:00
|
|
|
/**
|
|
|
|
* Computes the width of the string that fits into the available space
|
|
|
|
*
|
|
|
|
* @param in aLength total length of the string in PRUnichars
|
|
|
|
* @param in aMaxWidth width not to be exceeded
|
|
|
|
* @param out aMaxFit length of the string that fits within aMaxWidth
|
|
|
|
* in PRUnichars
|
|
|
|
* @return width of the string that fits within aMaxWidth
|
|
|
|
*/
|
|
|
|
nscoord MeasureString(const PRUnichar* aString,
|
|
|
|
PRInt32 aLength,
|
|
|
|
nscoord aMaxWidth,
|
|
|
|
PRUint32& aMaxFit,
|
|
|
|
nsIRenderingContext& aContext);
|
1999-04-14 01:50:25 +04:00
|
|
|
|
2004-08-01 03:15:21 +04:00
|
|
|
void DisplayAltText(nsPresContext* aPresContext,
|
1999-04-14 01:50:25 +04:00
|
|
|
nsIRenderingContext& aRenderingContext,
|
|
|
|
const nsString& aAltText,
|
|
|
|
const nsRect& aRect);
|
|
|
|
|
2006-01-26 05:29:17 +03:00
|
|
|
void PaintImage(nsIRenderingContext& aRenderingContext, nsPoint aPt,
|
|
|
|
const nsRect& aDirtyRect, imgIContainer* aImage);
|
|
|
|
|
2001-10-07 22:02:13 +04:00
|
|
|
protected:
|
2003-03-19 06:47:09 +03:00
|
|
|
friend class nsImageListener;
|
|
|
|
nsresult OnStartContainer(imgIRequest *aRequest, imgIContainer *aImage);
|
|
|
|
nsresult OnDataAvailable(imgIRequest *aRequest,
|
|
|
|
gfxIImageFrame *aFrame,
|
|
|
|
const nsRect * rect);
|
|
|
|
nsresult OnStopDecode(imgIRequest *aRequest,
|
|
|
|
nsresult aStatus,
|
|
|
|
const PRUnichar *aStatusArg);
|
|
|
|
nsresult FrameChanged(imgIContainer *aContainer,
|
|
|
|
gfxIImageFrame *aNewframe,
|
|
|
|
nsRect *aDirtyRect);
|
2001-05-04 10:29:59 +04:00
|
|
|
|
2003-03-19 06:47:09 +03:00
|
|
|
private:
|
|
|
|
// random helpers
|
|
|
|
inline void SpecToURI(const nsAString& aSpec, nsIIOService *aIOService,
|
|
|
|
nsIURI **aURI);
|
2001-05-04 10:29:59 +04:00
|
|
|
|
2004-08-01 03:15:21 +04:00
|
|
|
inline void GetLoadGroup(nsPresContext *aPresContext,
|
2003-03-19 06:47:09 +03:00
|
|
|
nsILoadGroup **aLoadGroup);
|
2001-11-01 18:31:13 +03:00
|
|
|
nscoord GetContinuationOffset(nscoord* aWidth = 0) const;
|
2003-06-17 20:40:34 +04:00
|
|
|
void GetDocumentCharacterSet(nsACString& aCharset) const;
|
2001-10-06 09:08:16 +04:00
|
|
|
|
2003-03-19 06:47:09 +03:00
|
|
|
/**
|
|
|
|
* This function will recalculate mTransform. If a non-null image
|
|
|
|
* is passed in, mIntrinsicSize will be recalculated from the image
|
|
|
|
* size. Otherwise, mIntrinsicSize will not be touched.
|
|
|
|
*
|
|
|
|
* @return PR_TRUE if aImage is non-null and its size did _not_
|
|
|
|
* match our previous intrinsic size
|
|
|
|
* @return PR_FALSE otherwise
|
|
|
|
*/
|
|
|
|
PRBool RecalculateTransform(imgIContainer* aImage);
|
2001-03-22 04:38:35 +03:00
|
|
|
|
2003-03-19 06:47:09 +03:00
|
|
|
/**
|
|
|
|
* Helper functions to check whether the request or image container
|
|
|
|
* corresponds to a load we don't care about. Most of the decoder
|
|
|
|
* observer methods will bail early if these return true.
|
|
|
|
*/
|
|
|
|
PRBool IsPendingLoad(imgIRequest* aRequest) const;
|
|
|
|
PRBool IsPendingLoad(imgIContainer* aContainer) const;
|
2001-03-22 04:38:35 +03:00
|
|
|
|
2001-10-06 09:08:16 +04:00
|
|
|
/**
|
2004-08-29 03:59:15 +04:00
|
|
|
* Function to convert a dirty rect in the source image to a dirty
|
|
|
|
* rect for the image frame.
|
2001-10-06 09:08:16 +04:00
|
|
|
*/
|
2004-08-29 03:59:15 +04:00
|
|
|
nsRect SourceRectToDest(const nsRect & aRect);
|
2003-03-19 06:47:09 +03:00
|
|
|
|
|
|
|
nsImageMap* mImageMap;
|
|
|
|
|
|
|
|
nsCOMPtr<imgIDecoderObserver> mListener;
|
2001-10-06 09:08:16 +04:00
|
|
|
|
2001-03-22 04:38:35 +03:00
|
|
|
nsSize mComputedSize;
|
|
|
|
nsSize mIntrinsicSize;
|
2003-03-19 06:47:09 +03:00
|
|
|
nsTransform2D mTransform;
|
|
|
|
|
2000-04-19 18:00:11 +04:00
|
|
|
nsMargin mBorderPadding;
|
2003-02-26 08:51:32 +03:00
|
|
|
|
2004-01-21 12:35:59 +03:00
|
|
|
static nsIIOService* sIOService;
|
|
|
|
|
2001-11-07 08:02:42 +03:00
|
|
|
/* loading / broken image icon support */
|
|
|
|
|
2003-03-19 06:47:09 +03:00
|
|
|
// XXXbz this should be handled by the prescontext, I think; that
|
|
|
|
// way we would have a single iconload per mozilla session instead
|
|
|
|
// of one per document...
|
|
|
|
|
|
|
|
// LoadIcons: initiate the loading of the static icons used to show
|
|
|
|
// loading / broken images
|
2004-08-01 03:15:21 +04:00
|
|
|
nsresult LoadIcons(nsPresContext *aPresContext);
|
|
|
|
nsresult LoadIcon(const nsAString& aSpec, nsPresContext *aPresContext,
|
2003-03-19 06:47:09 +03:00
|
|
|
imgIRequest **aRequest);
|
|
|
|
|
|
|
|
// HandleIconLoads: See if the request is for an Icon load. If it
|
|
|
|
// is, handle it and return TRUE otherwise, return FALSE (aCompleted
|
|
|
|
// is an input arg telling the routine if the request has completed)
|
2001-11-07 08:02:42 +03:00
|
|
|
PRBool HandleIconLoads(imgIRequest* aRequest, PRBool aCompleted);
|
2003-03-19 06:47:09 +03:00
|
|
|
|
2004-02-03 23:30:02 +03:00
|
|
|
class IconLoad : public nsIObserver {
|
2001-11-07 08:02:42 +03:00
|
|
|
// private class that wraps the data and logic needed for
|
|
|
|
// broken image and loading image icons
|
|
|
|
public:
|
2004-02-03 23:30:02 +03:00
|
|
|
IconLoad(imgIDecoderObserver* aObserver);
|
2003-03-19 06:47:09 +03:00
|
|
|
|
2004-02-03 23:30:02 +03:00
|
|
|
void Shutdown()
|
2003-03-17 19:09:02 +03:00
|
|
|
{
|
2004-02-03 23:30:02 +03:00
|
|
|
// in case the pref service releases us later
|
|
|
|
if (mLoadingImage) {
|
|
|
|
mLoadingImage->Cancel(NS_ERROR_FAILURE);
|
|
|
|
mLoadingImage = nsnull;
|
2003-03-17 19:09:02 +03:00
|
|
|
}
|
2004-02-03 23:30:02 +03:00
|
|
|
if (mBrokenImage) {
|
|
|
|
mBrokenImage->Cancel(NS_ERROR_FAILURE);
|
|
|
|
mBrokenImage = nsnull;
|
2003-03-17 19:09:02 +03:00
|
|
|
}
|
|
|
|
}
|
2003-03-19 06:47:09 +03:00
|
|
|
|
2004-02-03 23:30:02 +03:00
|
|
|
NS_DECL_ISUPPORTS
|
|
|
|
NS_DECL_NSIOBSERVER
|
2001-11-07 08:02:42 +03:00
|
|
|
|
2004-02-03 23:30:02 +03:00
|
|
|
private:
|
2004-04-30 03:34:19 +04:00
|
|
|
void GetPrefs();
|
2003-03-19 06:47:09 +03:00
|
|
|
|
|
|
|
public:
|
2004-02-03 23:30:02 +03:00
|
|
|
nsCOMPtr<imgIRequest> mLoadingImage;
|
|
|
|
nsCOMPtr<imgIRequest> mBrokenImage;
|
2003-04-02 07:19:50 +04:00
|
|
|
nsCOMPtr<imgIDecoderObserver> mLoadObserver; // keeps the observer alive
|
2004-02-03 23:30:02 +03:00
|
|
|
PRUint8 mIconsLoaded;
|
2001-11-07 08:02:42 +03:00
|
|
|
PRPackedBool mPrefForceInlineAltText;
|
2002-04-10 18:45:05 +04:00
|
|
|
PRPackedBool mPrefShowPlaceholders;
|
2001-11-07 08:02:42 +03:00
|
|
|
};
|
2006-01-26 05:29:17 +03:00
|
|
|
|
|
|
|
public:
|
2004-02-03 23:30:02 +03:00
|
|
|
static IconLoad* gIconLoad; // singleton pattern: one LoadIcons instance is used
|
2006-01-26 05:29:17 +03:00
|
|
|
|
|
|
|
friend class nsDisplayImage;
|
1999-04-14 01:50:25 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* nsImageFrame_h___ */
|