Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Comment: Confirmed.

Description

Metview Macro Library function. Used to plot a circle with a given radius in km onto a non-cylindrical map projection. Internally, the circle is split into a number of segments and the returned result is an Input Visualiser object which can be passed to the plot() command along with an optional Graph Plotting object.

Usage

definition mvl_geocircle(lat : number, lon : number,radius : number, resolution : number)

The first three parameters specify the centre and the radius (in km) of the circle. Parameter resolution defines the number of line segments to use to make up the circle.

Example


Code Block
languagepy
# Metview Macro

# **************************** LICENSE START ***********************************
# 
# Copyright 2017 ECMWF. This software is distributed under the terms
# of the Apache License version 2.0. In applying this license, ECMWF does not
# waive the privileges and immunities granted to it by virtue of its status as
# an Intergovernmental Organization or submit itself to any jurisdiction.
# 
# ***************************** LICENSE END ************************************

# ---------------------------------------------------------------
# Tags: mvl,coast
# Title: Geocircle on Map
# Description: Demonstrates how to plot a circle on any map
# projection using the Macro Library function
# mvl_geocircle.
# ---------------------------------------------------------------

# set up the shaded coastlines
land_sea_shade = mcoast
(
    map_coastline_land_shade        : "on",
    map_coastline_land_shade_colour : "RGB(0.98,0.95,0.82)",
    map_coastline_sea_shade         : "on",
    map_coastline_sea_shade_colour  : "RGB(0.85,0.93,1)"
)

# define the geographic view
view = geoview
(
    map_projection      : "polar_stereographic",
    map_area_definition : "corners",
    area                : [-5,-30,10,84],  # S,W,N,E
    coastlines          : land_sea_shade
)

# define the radius of the circles (in km) 
circle_radius = 200

# the circle will be made up of this many segments
circle_resolution = 80

# define the centres of the circles 
latPos=[58,48,38,28,18,8]
lonPos=[-20,-8,4,16,28,40]

# build the plot the finition of the circles
pltLst=nil
for i=1 to count(latPos) do

    # define the cirle around the specifed coordinates
    iv_circle = mvl_geocircle(latPos[i],lonPos[i],circle_radius,circle_resolution)

    # define the plotting attributes for the circle 
    graph_circle = mgraph
    (
        graph_line_colour    : "red",
        graph_line_thickness : "4",
        graph_line_style     : 'solid'
    )

    # collect the plot definitions into a list
    pltLst=pltLst & [iv_circle,graph_circle]

end for

# define the output media
to_pdf_file = pdf_output
(
    output_name : "plot" # extension is added automatically
)

# check the runmode and decide which media to put the plot to
mode = runmode()
if  mode = "execute" or mode = "batch" then
    setoutput(to_pdf_file)
end if

# plot the circles on the map
plot(view, pltLst)