Мне нужно что-то вроде следующего, но с разным цветом для каждого слова в строке:
library(grid)
grid.newpage()
pushViewport(viewport(width = unit(5, 'cm'), height = unit(5, 'cm')))
grid.rect()
grid.text(label = 'Hello, World!')
Я пытался создать отдельные гроб для каждого сегмента, а затем сгруппировать их вместе, но я не могу понять, Как расположить результат в центре области просмотра:
grid.newpage()
pushViewport(viewport(width = unit(5, 'cm'), height = unit(5, 'cm')))
grid.rect()
grouped_grobs <-
gList(textGrob(label = 'Hello',
x = unit(0.0, 'npc'),
y = unit(0.5, 'npc'),
just = c('left', 'center'),
gp = gpar(col='red')),
textGrob(label = ',',
x = unit(1, 'strwidth', data = 'Hello'),
y = unit(0.5, 'npc'),
just = c('left', 'center'),
gp = gpar(col='black')),
textGrob(label = 'World',
x = unit(1, 'strwidth', data = 'Hello, '),
y = unit(0.5, 'npc'),
just = c('left', 'center'),
gp = gpar(col='blue')),
textGrob(label = '!',
x = unit(1, 'strwidth', data = 'Hello, World'),
y = unit(0.5, 'npc'),
just = c('left', 'center'),
gp = gpar(col='black')))
grid.draw(grouped_grobs)
Я пытался измерить ширину gList, я также пытался использовать gTree, но почему-то я застрял в этой, казалось бы, простой задаче.
Заранее спасибо за любую помощь!