Microstation DGN

Driver short name

DGN

Driver built-in by default

This driver is built-in by default

Microstation DGN files from Microstation versions predating version 8.0 are supported for reading (a DGNv8 driver, using Teigha libraries, is available to read and write DGN v8 files). The entire file is represented as one layer (named "elements").

DGN files are considered to have no georeferencing information through OGR. Features will all have the following generic attributes:

  • Type: The integer type code as listed below in supported elements.

  • Level: The DGN level number (0-63).

  • GraphicGroup: The graphic group number.

  • ColorIndex: The color index from the dgn palette.

  • Weight: The drawing weight (thickness) for the element.

  • Style: The style value for the element.

  • EntityNum and MSLink: The Entity ID and MSLINK values in database linkage.

  • ULink: User data linkage (multiple user data linkages may exist for each element).

DGN files do not contain spatial indexes; however, the DGN driver does take advantage of the extents information at the beginning of each element to minimize processing of elements outside the current spatial filter window when in effect.

Driver capabilities

Supports Create()

This driver supports the GDALDriver::Create() operation

Supports Georeferencing

This driver supports georeferencing

Supports VirtualIO

This driver supports virtual I/O operations (/vsimem/, etc.)

Supported Elements

The following element types are supported:

  • Line (3): Line geometry.

  • Line String (4): Multi segment line geometry.

  • Shape (6): Polygon geometry.

  • Curve (11): Approximated as a line geometry.

  • B-Spline (21): Treated (inaccurately) as a line geometry.

  • Arc (16): Approximated as a line geometry.

  • Ellipse (15): Approximated as a line geometry.

  • Text (17): Treated as a point geometry.

Generally speaking any concept of complex objects, and cells as associated components is lost. Each component of a complex object or cell is treated as a independent feature.

User data linkage

A DGN element may have multiple user data linkages. Each linkage has a user id, application id and a number of words of data. The user data linkage output reports the data for each different application id found as raw hexadecimal words (16bits). The application id is the second word of the raw data.

Is up to the user how to decode the user raw data, depending on the application id.

Styling Information

Some drawing information about features can be extracted from the ColorIndex, Weight and Style generic attributes; however, for all features an OGR style string has been prepared with the values encoded in ready-to-use form for applications supporting OGR style strings.

The various kinds of linear geometries will carry style information indicating the color, thickness and line style (i.e. dotted, solid, etc).

Polygons (Shape elements) will carry styling information for the edge as well as a fill color if provided. Fill patterns are not supported.

Text elements will contain the text, angle, color and size information (expressed in ground units) in the style string.

Creation Issues

2D DGN files may be written with OGR with significant limitations:

  • Output features have the usual fixed DGN attributes. Attempts to create any other fields will fail.

  • Virtual no effort is currently made to translate OGR feature style strings back into DGN representation information.

  • POINT geometries that are not text (Text is NULL, and the feature style string is not a LABEL) will be translated as a degenerate (0 length) line element.

  • Polygon, and multipolygon objects will be translated to simple polygons with all rings other than the first discarded.

  • Polygons and line strings with too many vertices will be split into a group of elements prefixed with a Complex Shape Header or Complex Chain Header element as appropriate.

  • A seed file must be provided (or if not provided, $PREFIX/share/gdal/seed_2d.dgn will be used). Many aspects of the resulting DGN file are determined by the seed file, and cannot be affected via OGR, such as initial view window.

  • The various collection geometries other than MultiPolygon are completely discarded at this time.

  • Geometries which fall outside the "design plane" of the seed file will be discarded, or corrupted in unpredictable ways.

  • DGN files can only have one layer. Attempts to create more than one layer in a DGN file will fail.

Open options

Added in version 3.10.

Open options can be specified in command-line tools using the syntax -oo <NAME>=<VALUE> or by providing the appropriate arguments to GDALOpenEx() (C) or gdal.OpenEx (Python). The following open options are supported:

  • ENCODING=<encoding>: (GDAL >= 3.10) An encoding name supported by CPLRecode() (i.e. an iconv name) that indicates the encoding used by Text elements in the DGN file, to recode them to UTF-8. If not specified (or specified to UTF-8), no recoding will be done.

Dataset creation options

Dataset creation options can be specified in command-line tools using the syntax -dsco <NAME>=<VALUE> or by providing the appropriate arguments to GDALCreate() (C) or Driver.Create (Python). The following dataset-creation options are supported:

  • 3D=[YES​/​NO]: Determine whether 2D (seed_2d.dgn) or 3D (seed_3d.dgn) seed file should be used. This option is ignored if the SEED option is provided.

  • SEED=<filename>: Override the seed file to use.

  • COPY_WHOLE_SEED_FILE=[YES​/​NO]: Defaults to NO. Indicate whether the whole seed file should be copied. If not, only the first three elements (and potentially the color table) will be copied.

  • COPY_SEED_FILE_COLOR_TABLE=[YES​/​NO]: Defaults to NO. Indicates whether the color table should be copied from the seed file.

  • MASTER_UNIT_NAME=value: Override the master unit name from the seed file with the provided one or two character unit name.

  • SUB_UNIT_NAME=value: Override the sub unit name from the seed file with the provided one or two character unit name.

  • SUB_UNITS_PER_MASTER_UNIT=value: Override the number of subunits per master unit. By default the seed file value is used.

  • UOR_PER_SUB_UNIT=value: Override the number of UORs (Units of Resolution) per sub unit. By default the seed file value is used.

  • ORIGIN=<x,y,z>: Override the origin of the design plane. By default the origin from the seed file is used.

  • ENCODING=<encoding>: (GDAL >= 3.10) An encoding name supported by CPLRecode() (i.e. an iconv name) that indicates the encoding used by Text elements in the DGN file, to recode them from UTF-8. If not specified (or specified to UTF-8), no recoding will be done. "ISO-8859-1" (ISO Latin1) is supported even on builds without iconv support. Note that no fields in the DGN file itself contain the encoding name, hence it is the responsibility of the reader to open the file with the same value for the ENCODING open option.