author Jon Coppeard <>
Mon, 02 Jun 2014 16:10:53 +0100
changeset 186170 ac7043963695f9404427d7c6c4a4cf6594d54d63
parent 146055 eb9ce350a4adde7b645b30d2a6faaf80b5e62b85
child 201106 3bc727b5027c0caa433cdc83c7e6c962e6083890
permissions -rw-r--r--
Bug 1008473 - Make Value::toGCThing() return a Cell pointer rather than void* r=terrence

/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at */

/* code for HTML client-side image maps */

#ifndef nsImageMap_h
#define nsImageMap_h

#include "nsCOMPtr.h"
#include "nsCoord.h"
#include "nsTArray.h"
#include "nsStubMutationObserver.h"
#include "nsIDOMEventListener.h"

class Area;
class nsRenderingContext;
class nsImageFrame;
class nsIFrame;
class nsIContent;
struct nsRect;

class nsImageMap : public nsStubMutationObserver,
                   public nsIDOMEventListener

  nsresult Init(nsImageFrame* aImageFrame, nsIContent* aMap);

   * Return the first area element (in content order) for the given aX,aY pixel
   * coordinate or nullptr if the coordinate is outside all areas.
  nsIContent* GetArea(nscoord aX, nscoord aY) const;

   * Return area elements count associated with the image map.
  uint32_t AreaCount() const { return mAreas.Length(); }

   * Return area element at the given index.
  nsIContent* GetAreaAt(uint32_t aIndex) const;

  void Draw(nsIFrame* aFrame, nsRenderingContext& aRC);
   * Called just before the nsImageFrame releases us. 
   * Used to break the cycle caused by the DOM listener.
  void Destroy();
  // nsISupports

  // nsIMutationObserver


  nsresult GetBoundsForAreaContent(nsIContent *aContent,
                                   nsRect& aBounds);

  virtual ~nsImageMap();

  void FreeAreas();

  nsresult UpdateAreas();
  nsresult SearchForAreas(nsIContent* aParent, bool& aFoundArea,
                          bool& aFoundAnchor);

  nsresult AddArea(nsIContent* aArea);
  void MaybeUpdateAreas(nsIContent *aContent);

  nsImageFrame* mImageFrame;  // the frame that owns us
  nsCOMPtr<nsIContent> mMap;
  nsAutoTArray<Area*, 8> mAreas; // almost always has some entries
  bool mContainsBlockContents;

#endif /* nsImageMap_h */