當前位置: 首頁>>代碼示例>>Python>>正文


Python mapnik.Map方法代碼示例

本文整理匯總了Python中mapnik.Map方法的典型用法代碼示例。如果您正苦於以下問題:Python mapnik.Map方法的具體用法?Python mapnik.Map怎麽用?Python mapnik.Map使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在mapnik的用法示例。


在下文中一共展示了mapnik.Map方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: __init__

# 需要導入模塊: import mapnik [as 別名]
# 或者: from mapnik import Map [as 別名]
def __init__(self, size, stylesheet):
        self._map = mapnik.Map(size, size)
        mapnik.load_map(self._map, stylesheet) 
開發者ID:perliedman,項目名稱:shadow-mapper,代碼行數:5,代碼來源:render_background.py

示例2: generate_image

# 需要導入模塊: import mapnik [as 別名]
# 或者: from mapnik import Map [as 別名]
def generate_image(xml, filename, ext, ftype, ll, dx, dy, res, verbose, force):
	print "generate_image:", xml, filename
	mapfile 	= xml
	
	merc 		= "+proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0 +k=1.0 +units=m +nadgrids=@null +no_defs +over"
	latlon		= "+proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs"
	
	m 			= mapnik.Map(dx, dy)
	
	mapnik.load_map(m, mapfile)
	
	# Override projection defined in mapfile    
	m.srs 	= latlon
	#m.srs 	= merc
	
	# Calculate projected boundaries
	prj 	= mapnik.Projection(m.srs)
	c0 		= prj.forward(mapnik.Coord(ll[0], ll[1]))
	c1 		= prj.forward(mapnik.Coord(ll[2], ll[3]))

	# Apply bounding box
	bbox 	= mapnik.Envelope(c0.x, c0.y, c1.x, c1.y)
	m.zoom_to_box(bbox)

	# Render image
	im 		= mapnik.Image(dx, dy)
	mapnik.render(m, im)
	
	view 	= im.view(0, 0, dx, dy)

	png_file = filename + ext	#".png"
	
	if force or not os.path.isfile(png_file):
		if verbose:
			print( "saving "+ png_file)
		view.save(png_file, ftype)
	
	
# Main
#  geojson_osm.py --bbox 20.0 -20.0 30.00 -10.00 --img 4551 4551 --res 0.00219726562502 --dir . -v 
開發者ID:vightel,項目名稱:FloodMapsWorkshop,代碼行數:42,代碼來源:geojson_osm.py

示例3: generate_image

# 需要導入模塊: import mapnik [as 別名]
# 或者: from mapnik import Map [as 別名]
def generate_image(self, xml, filename, ext, ftype, ll, dx, dy, res, verbose, force):
		print "generate_image:", xml, filename
		mapfile 	= xml
	
		merc 		= "+proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0 +k=1.0 +units=m +nadgrids=@null +no_defs +over"
		latlon		= "+proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs"
	
		m 			= mapnik.Map(dx, dy)
	
		mapnik.load_map(m, mapfile)
	
		# Override projection defined in mapfile    
		m.srs 	= latlon
		#m.srs 	= merc
	
		# Calculate projected boundaries
		prj 	= mapnik.Projection(m.srs)
		c0 		= prj.forward(mapnik.Coord(ll[0], ll[1]))
		c1 		= prj.forward(mapnik.Coord(ll[2], ll[3]))

		# Apply bounding box
		bbox 	= mapnik.Envelope(c0.x, c0.y, c1.x, c1.y)
		m.zoom_to_box(bbox)

		# Render image
		im 		= mapnik.Image(dx, dy)
		mapnik.render(m, im)
	
		view 	= im.view(0, 0, dx, dy)

		png_file = filename + ext	#".png"
	
		if force or not os.path.isfile(png_file):
			if verbose:
				print( "saving "+ png_file)
			view.save(png_file, ftype) 
開發者ID:vightel,項目名稱:FloodMapsWorkshop,代碼行數:38,代碼來源:modis.py

示例4: style_map

# 需要導入模塊: import mapnik [as 別名]
# 或者: from mapnik import Map [as 別名]
def style_map(self, Map):
        style = mapnik.Style()
        rule = mapnik.Rule()

        sym = mapnik.RasterSymbolizer()
        sym.opacity = self.opacity

        colorizer = mapnik.RasterColorizer(
            mapnik.COLORIZER_DISCRETE,
            mapnik.Color('white')
        )
        # colorizer.epsilon = 0.001
        if self.colormap:
            for stop in self.colormap:
                colorizer.add_stop(stop['quantity'], mapnik.Color(
                    stop['color'].encode('ascii')))

        sym.colorizer = colorizer

        rule.symbols.append(sym)
        style.rules.append(rule)

        Map.append_style('Raster Style', style)

        lyr = mapnik.Layer('GDAL Layer from TIFF', self.layer_srs)

        lyr.datasource = mapnik.Gdal(base=os.path.dirname(self.vrt_path),
                                     file=os.path.basename(self.vrt_path),
                                     band=self.mapnik_band)

        lyr.styles.append('Raster Style')

        Map.layers.append(lyr)

        return Map 
開發者ID:OpenGeoscience,項目名稱:geonotebook,代碼行數:37,代碼來源:provider.py

示例5: renderArea

# 需要導入模塊: import mapnik [as 別名]
# 或者: from mapnik import Map [as 別名]
def renderArea(self, width, height, srs, xmin, ymin, xmax, ymax, zoom):
        '''
        '''

        # NB: To be thread-safe Map object cannot be stored in the class state.
        # see: https://groups.google.com/forum/#!topic/mapnik/USDlVfSk328

        Map = mapnik.Map(width, height, srs)
        Map.zoom_to_box(Box2d(xmin, ymin, xmax, ymax))

        Map = self.style_map(Map)

        img = mapnik.Image(width, height)
        # Don't even call render with scale factor if it's not
        # defined. Plays safe with older versions.
        if self.scale_factor is None:
            mapnik.render(Map, img)
        else:
            mapnik.render(Map, img, self.scale_factor)

        def gamma_correct(im):
            """Fast gamma correction with PIL's image.point() method."""
            if self.gamma != 1.0:
                table = [pow(x / 255., 1.0 / self.gamma) * 255
                         for x in range(256)]
                # Expand table to number of bands
                table = table * len(im.mode)
                return im.point(table)
            else:
                return im

        # b = BytesIO(img.tostring())
        img = Image.frombytes('RGBA', (width, height), img.tostring())

        img = gamma_correct(img)

        return img 
開發者ID:OpenGeoscience,項目名稱:geonotebook,代碼行數:39,代碼來源:provider.py

示例6: prepare_ozi

# 需要導入模塊: import mapnik [as 別名]
# 或者: from mapnik import Map [as 別名]
def prepare_ozi(mbbox, mwidth, mheight, name, transform):
    """Create georeferencing file for OziExplorer"""
    def deg(value, is_lon):
        degrees = math.floor(abs(value))
        minutes = (abs(value) - degrees) * 60
        return '{:4d},{:3.5F},{}'.format(
            int(round(degrees)), minutes,
            ('W' if is_lon else 'S') if value < 0 else ('E' if is_lon else 'N'))

    ozipoint = ('Point{:02d},xy,     ,     ,in, deg,    ,        ,N,    ,        ,E' +
                ', grid,   ,           ,           ,N')
    bbox = transform.backward(mbbox)
    points = "\n".join([ozipoint.format(n) for n in range(3, 31)])
    header = '''OziExplorer Map Data File Version 2.2
Nik4
{name}
1 ,Map Code,
WGS 84,WGS 84,   0.0000,   0.0000,WGS 84
Reserved 1
Reserved 2
Magnetic Variation,,,E
Map Projection,Mercator,PolyCal,No,AutoCalOnly,No,BSBUseWPX,No
Point01,xy,    0,    0,in, deg,{top},{left}, grid,   ,           ,           ,N
Point02,xy, {width:4d}, {height:4d},in, deg,{bottom},{right}, grid,   ,           ,           ,N
{points}
Projection Setup,,,,,,,,,,
Map Feature = MF ; Map Comment = MC     These follow if they exist
Track File = TF      These follow if they exist
Moving Map Parameters = MM?    These follow if they exist
MM0,Yes
MMPNUM,4
MMPXY,1,0,0
'''.format(name=name,
           top=deg(bbox.maxy, False),
           left=deg(bbox.minx, True),
           width=mwidth - 1,
           height=mheight - 1,
           bottom=deg(bbox.miny, False),
           right=deg(bbox.maxx, True),
           points=points)
    return ''.join([
        header,
        "MMPXY,2,{},0\n".format(mwidth),
        "MMPXY,3,{},{}\n".format(mwidth, mheight),
        "MMPXY,4,0,{}\n".format(mheight),
        'MMPLL,1,{:4.6f},{:4.6f}\n'.format(bbox.minx, bbox.maxy),
        'MMPLL,2,{:4.6f},{:4.6f}\n'.format(bbox.maxx, bbox.maxy),
        'MMPLL,3,{:4.6f},{:4.6f}\n'.format(bbox.maxx, bbox.miny),
        'MMPLL,4,{:4.6f},{:4.6f}\n'.format(bbox.minx, bbox.miny),
        "MM1B,{}\n".format((mbbox.maxx - mbbox.minx) / mwidth * math.cos(
            math.radians(bbox.center().y))),
        "MOP,Map Open Position,0,0\n",
        "IWH,Map Image Width/Height,{},{}\n".format(mwidth, mheight),
    ]) 
開發者ID:Zverik,項目名稱:Nik4,代碼行數:56,代碼來源:nik4.py


注:本文中的mapnik.Map方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。