[whatwg] hit regions: clearing of regions
Rik Cabanier
cabanier at gmail.com
Tue Mar 11 16:13:29 PDT 2014
On Tue, Mar 11, 2014 at 10:03 AM, Edward O'Connor <eoconnor at apple.com>wrote:
> Hi Rik,
>
> You wrote:
>
> > Currently, the specification states that if you create a region and
> > then create another region that completely covers region, the first
> > region is removed from the hit region list [1]
> >
> > This is a complex operation that involves either drawing the regions
> > to a bitmaps and counting pixels, or path intersection. It is also
> > unintuitive because an author might expect that he could remove the
> > second region and still have the first region active.
> >
> > What was the reason that this was added to the spec?
>
> The model the spec uses for hit regions is that you have two bitmaps--one
> for the canvas surface, and the other is used to track which hit region
> the pixels of the canvas surface are in. See this thread from 2012:
>
>
> http://lists.whatwg.org/htdig.cgi/whatwg-whatwg.org/2012-July/thread.html#36556
Thanks!
It looks like that thread never came to a conclusion.
The arguments against using a bitmap presentation still stand:
- it will be too expensive to keep an actual copy of the canvas pixels in
memory to do hit testing
- if you have to mimic the behavior with paths, you need access to
expensive/difficult path manipulation algorithms
Hit regions should be redesigned so they work on the path geometry as
opposed to pixels. We already have the necessary code to do hit testing on
paths (see isPointInPath)
More information about the whatwg
mailing list