|
Размещаем стандартные текстовые элементы на графике
На одном из прошлых
занятий мы увидели, как можно строить двумерные линейные графики с помощью
функции plot() и задавать
различные стили его отображения: цвет, тип, толщину линии. На этом занятии
продолжим тему оформления графиков и начнем с сетки. Как мы уже говорили, в
самом простом случае достаточно вызвать команду grid():
import numpy as np
import matplotlib.pyplot as plt
y = np.arange(0, 5, 1)
x = np.array([a*a for a in y])
y2 = [0, 2, 3, 4, 5, 7]
x2 = [i+1 for i in y2]
lines = plt.plot(x, y, x2, y2)
plt.grid()
plt.show()
И сетка появится
сформируется в текущих координатных осях:
Причем, ее
размеры будут автоматически подстраиваться под размер осей (объекта Axes).
Помимо обычной
крупной сетки (major grid) можно наложить
более мелкую (minor grid) минорную
сетку. Для этого сначала нужно включить режим отображения минорной сетки:
А, затем, в
функции grid() прописать два
типа сеток (мажорную и минорную):
plt.grid(which='major', color = '#444', linewidth = 1)
plt.grid(which='minor', color='#aaa', ls=':')
В результате,
график приобретет вид:
Однако, здесь
следует иметь в виду, что такая мелкая сетка заметно снижает производительность
при отображении графиков. Поэтому без особой необходимости ее лучше не использовать.
Создание надписей и подписей
У каждой оси
(объекта Axes) можно
определять следующие текстовые элементы:
- title
– заголовок
для осей;
- xlabel, ylabel – подписи для
каждой из осей;
- text – произвольная
текстовая информация в области осей;
- annotate – аннотация
(текст с указателем).
Также, у окна в
целом можно задавать такие текстовые элементы:
- subtitle – заголовок для
фигуры (окна);
- figtext – размещение
произвольной текстовой информации в области окна.
Давайте в
качестве примера посмотрим, как работают все эти элементы на графике:
fig = plt.figure(figsize=(7, 4))
ax = fig.add_subplot()
plt.figtext(0.05, 0.6, 'Текст в области окна')
fig.suptitle('Заголовок окна')
ax.set_xlabel('Ox')
ax.set_ylabel('Oy')
ax.text(0.05, 0.1, 'Произвольный текст в координатных осях')
ax.annotate('Аннотация', xy=(0.2, 0.4), xytext=(0.6, 0.7),
arrowprops={'facecolor': 'gray', 'shrink': 0.1})
plt.show()
Обратите
внимание, если у нас используется всего одна координатная ось, то подписи для
нее можно определить с помощью функций:
plt.xlabel('Ox')
plt.ylabel('Oy')
Если же объектов
Axes несколько, то
эти функции будут относиться к последней активной оси.
Оформление текстовых элементов
Теперь перейдем
к оформлению на уровне текстовых блоков. Как правило, все текстовые элементы в matplotlib – это объекты
класса Text. И у них
имеются стандартный набор свойств для их оформления. Полный их перечень можно
посмотреть на странице официальной документации:
https://matplotlib.org/stable/api/text_api.html
Я же приведу
наиболее употребительные:
Свойство
|
Описание
|
alpha
|
степень
прозрачности (число в диапазоне [0; 1])
|
backgroundcolor
|
цвет
фона
|
color
или c
|
цвет
текста
|
fontfamily
или family
|
тип
шрифта
|
fontsize
или size
|
размер
шрифта
|
fontstyle
или style
|
стиль
шрифта: {'normal', 'italic', 'oblique'}
|
fontweight
или weight
|
степень
утолщения – число от 0 до 1000 или константы: 'ultralight', 'light',
'normal', 'regular', 'book', 'medium', 'roman', 'semibold', 'demibold',
'demi', 'bold', 'heavy', 'extra bold', 'black'
|
horizontalalignment
или ha
|
выравнивание
по горизонтали: {'center', 'right', 'left'}
|
label
|
текст
заголовка
|
position
|
координаты
текста (x,
y)
|
rotation
|
поворот
текста: вещественное число [0; 1] или константы {'vertical', 'horizontal'}
|
verticalalignment
или va
|
выравнивание
по вертикали: {'center', 'top', 'bottom', 'baseline', 'center_baseline'}
|
visible
|
отображение
текста: True/False
|
x
|
координата
x
– вещественное
число [0;
1]
|
y
|
координата
y
– вещественное
число [0;
1]
|
Использовать эти
свойства очень просто. Например, в функции figtext() пропишем именованный
параметр fontsize:
plt.figtext(0.05, 0.6, 'Текст в области окна', fontsize=24)
Теперь текст
отображается с новым размером шрифта. Или, можно еще указать цвет:
plt.figtext(0.05, 0.6, 'Текст в области окна', fontsize=24, color='r')
Получим текст
размером 24 и красным цветом. По аналогии задаются все другие свойства.
Также следует
иметь в виду, что у каждого типа текстовых объектов имеются и свои
дополнительные свойства. Подробно о них можно посмотреть в документации.
Параметр bbox
С помощью
параметра bbox можно
устанавливать дополнительные элементы оформления для текстовых блоков. Ему
следует указать словарь, ключами которого являются аргументы класса FancyBboxPatch:
Свойство
|
Описание
|
boxstyle
|
вид
рамки вокруг текста
|
alpha
|
степень
прозрачности фона
|
color
|
цвет
фона с рамкой
|
edgecolor или ec
|
цвет
рамки
|
facecolor или fc
|
цвет
заливки
|
fill
|
использовать
ли заливку: True/False
|
hatch
|
тип штриховки:
{'/', '\', '|', '-', '+', 'x', 'o', 'O', '.', '*'}
|
linestyle или ls
|
стиль линии границы:
{'-', '--', '-.', ':', '', (offset, on-offseq), ...}
|
linewidth или lw
|
толщина
рамки
|
В качестве
параметра boxstyle можно выбирать следующие значения:
Атрибут
|
Описание
|
Вид
|
circle
|
имеет
параметр pad (отступ от
границы)
|
|
darrow
|
имеет
параметр pad
|
|
larrow
|
имеет
параметр pad
|
|
rarrow
|
имеет
параметр pad
|
|
round
|
имеет параметры:
pad, rounding_size
|
|
roundtooth
|
имеет параметры:
pad, tooth_size
|
|
sawtooth
|
имеет параметры:
pad, tooth_size
|
|
square
|
имеет
параметр pad
|
|
Пример
использования:
ax.text(15, 2, 'Текст', bbox={'boxstyle':'darrow', 'facecolor': '#AAAAFF'})
ax.plot(np.arange(0, 5, 0.25))
Цвет фона фигуры и координатных осей
Используя
параметр facecolor можно задавать цвет фона для всей формы и отдельно для
координатных осей. Например, если при создании фигуры указать этот параметр в
виде:
fig = plt.figure(figsize=(7, 4), facecolor='#eee')
то получим
светло-серую заливку фона окна. Или, это можно сделать с помощью метода set() после
создания фигуры:
fig.set(facecolor='#eee')
То же самое
выполняется и для координатных осей, например, изменим цвет фона на
светло-зеленый:
ax.set(facecolor='#AAFFAA')
На этом мы
завершим знакомство с типовыми элементами оформления графиков. На следующем
продолжим эту тему и поговорим об отображении легенды – краткой информации по
каждому графику и возможности рисования стандартных геометрических фигур.
|