PointStyle - Стиль точек

digraph geometry {
    node [shape="box", style=filled, fillcolor="lightgray"]
    rankdir=LR
    labelloc="t";
    label="Иерархия классов стилей геометрических объектов:";

    Style  [ href="Style.html#ref-label-style-class" ];
    PointStyle  [ href="PointStyle.html#ref-label-pointstyle-class", fillcolor=green, style=filled];
    PointCompatStyle  [ href="PointCompatStyle.html#ref-label-pointcompatstyle-class" ];
    PointFontStyle  [ href="PointFontStyle.html#ref-label-pointfontstyle-class" ];
    PointPictureStyle  [ href="PointPictureStyle.html#ref-label-pointpicturestyle-class" ];

    Style -> PointStyle;
    PointStyle -> PointCompatStyle;
    PointStyle -> PointFontStyle;
    PointStyle -> PointPictureStyle;
}
class axipy.da.PointStyle

Базовые классы: axipy.da.Style

Стиль оформления точечных объектов.

По умолчанию создается стиль на базе шрифта True Type, а параметры аналогичны значениям по умолчанию в методе create_mi_font().

Поддерживается 3 вида оформления:

  • Совместимое с MapInfo версии 3. Для создания такого стиля необходимо использовать create_mi_compat().

  • На базе шрифтов True Type. Задано по умолчанию. Стиль создается посредством create_mi_font().

  • На базе растрового файла. Стиль можно создать с помощью create_mi_picture().

Пример.
style_1 = PointStyle.create_mi_compat(color = Qt.blue)
style_2 = PointStyle.create_mi_font(42, Qt.red, 24)
style_3 = PointStyle.create_mi_picture('AMBU-64.bmp')

Methods:

clone()

Создаёт копию объекта стиля

create_mi_compat([symbol, color, pointSize])

Создание стиля в виде совместимого с MapInfo 3 PointCompatStyle.

create_mi_font([symbol, color, size, …])

Создание стиля на базе шрифта True Type PointFontStyle.

create_mi_picture(filename[, color, size, …])

Создание стиля с ссылкой на растровый файл PointPictureStyle.

draw(geometry, painter)

Рисует геометрический объект с текущим стилем в произвольном контексте вывода.

for_geometry(geom)

Возвращает стиль по умолчанию для переданного объекта.

from_mapinfo(mapbasic_string)

Получает стиль из строки формата MapBasic.

to_mapinfo()

Возвращает строковое представление в формате MapBasic.

Attributes:

color

Цвет символа.

clone()

Создаёт копию объекта стиля

Тип результата

Style

property color

Цвет символа.

Тип результата

QColor

static create_mi_compat(symbol=35, color=PySide2.QtCore.Qt.GlobalColor.red, pointSize=8)

Создание стиля в виде совместимого с MapInfo 3 PointCompatStyle.

Параметры
  • symbol (int) – Номер символа, который будет отображен при отрисовке. Для создания невидимого символа используйте значение 31. Стандартный набор условных знаков включает символы от 31 до 67,

  • color (QColor) – Цвет символа

  • pointSize (int) – Целое число, размер символа в пунктах от 1 до 48.

Тип результата

PointCompatStyle

static create_mi_font(symbol=36, color=PySide2.QtCore.Qt.GlobalColor.red, size=8, fontname='Axioma MI MapSymbols', fontstyle=0, rotation=0.0)

Создание стиля на базе шрифта True Type PointFontStyle.

Параметры
  • symbol (int) – Целое, имеющее значение 31 или больше, определяющее, какой используется символ из шрифтов TrueType. Для создания невидимого символа используйте значение 31.

  • color (QColor) – Цвет символа

  • pointSize – Целое число, размер символа в пунктах от 1 до 48;

  • fontname (str) – Строка с именем шрифта TrueType (например, значение по умолчание „Axioma MI MapSymbols“)

  • fontstyle (int) – Стиль дополнительного оформления, например, курсивный текст. Возможные параметры см. в таблице ниже. Для указания нескольких параметров их суммируют между собой.

  • rotation (float) – Угол поворота символа в градусах.

Тип результата

PointFontStyle

static create_mi_picture(filename, color=PySide2.QtCore.Qt.GlobalColor.black, size=12, customstyle=0)

Создание стиля с ссылкой на растровый файл PointPictureStyle.

Параметры
  • filename (str) – Наименование растрового файла. Строка до 31 символа длиной. Данный файл должен находится в каталоге CustSymb с ресурсами. Например, “Arrow.BMP”.

  • color (QColor) – Цвет символа.

  • size (int) – Размер символа в в пунктах от 1 до 48.

  • customstyle (int) – Задание дополнительных параметров стиля оформления.

Тип результата

PointPictureStyle

draw(geometry, painter)

Рисует геометрический объект с текущим стилем в произвольном контексте вывода. Это может быть востребовано при желании отрисовать геометрию со стилем на форме или диалоге.

Параметры
  • geometry (Geometry) – Геометрия. Должна соответствовать стилю. Т.е. если объект полигон, а стиль для рисования точечных объектов, то ничего нарисовано не будет.

  • painter (QPainter) – Контекст вывода.

Пример отрисовки в растре и сохранение результата в файле.
image = QImage(100, 100, QImage.Format_ARGB32_Premultiplied)
image.fill(Qt.white)
painter = QPainter(image)
point = Point(50,50)
style = PointStyle.create_mi_font(42, Qt.red, 24)
style.draw(point, painter)
image.save(filename)
classmethod for_geometry(geom)

Возвращает стиль по умолчанию для переданного объекта.

Параметры

geom (Geometry) – Геометрический объект, для которого необходимо получить соответствующий ему стиль.

Тип результата

Style

classmethod from_mapinfo(mapbasic_string)

Получает стиль из строки формата MapBasic.

Параметры

mapbasic_string (str) – Строка в формате MapBasic.

style = Style.from_mapinfo("Pen (1, 2, 0) Brush (8, 255)")
Тип результата

Style

to_mapinfo()

Возвращает строковое представление в формате MapBasic.

style.to_mapinfo()
'''
>>> Pen (1, 2, 0) Brush (8, 255)
'''
Тип результата

str