I believe the current chameleonic algorithm is a bit broken. I was
trying to trace what it actually does, it looks at the 4 corners of the
screen and the center spot, then if there is much of a difference it
recursively does this for each quadrant in turn until the points are
roughly even in colour. This sounds good in theory, and works reasonably
well in practice, but it overemphasises a diagonal cross in the center
of the screen and basically diagonal lines growing from each point it
looks at. There is probably a much better algorithm that could be
dropped in, perhaps just one sampling 16 random points or points on a
grid would be just as good in effect and would run in a shorter,
constant, time. Currently if the center point and 4 corners match then
it stops very fast, but doesn't see any variations elsewhere in the
image, for other images it will recursively average quite a lot of points.
Alan.
--
I work at http://libertus.co.uk
--
Mailing list: https://launchpad.net/~unity-design
Post to : unity-design@lists.launchpad.net
Unsubscribe : https://launchpad.net/~unity-design
More help : https://help.launchpad.net/ListHelp