aboutsummaryrefslogtreecommitdiff
path: root/pixelmappers/GaussianMapper.py
blob: e94235ec51c8918f3eed393b664f2fc24858e23b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
from operationscore.PixelMapper import *
import util.Geo as Geo
import Util
class GaussianMapper(PixelMapper):
    def mappingFunction(self, eventLocation, screen):
        returnPixels = [] #TODO: consider preallocation and trimming
        [x,y] = eventLocation
        for (x,pixel) in screen.pixelsInRange(x-self['CutoffDist'], \
                x+self['CutoffDist']):
            pixelDist = Geo.dist(pixel.location, eventLocation)
            if pixelDist < self['CutoffDist']:
                w = Geo.gaussian(pixelDist, self['Height'], 0, self['Width'])
                returnPixels.append((pixel, w))
        return returnPixels