Проблемы с географическими координатами с R tkplot
Я хочу расположить вершину графа с географическими координатами (epsg:27572), но когда я использую tkplot
функция tkplot.setcoords()
, координаты "центрированы", появляется один 0, а пространственная локализация является разновидностью зеркальной симметрии истинных положений. Пример:
library(igraph)
library(tcltk)
relations <- read.table(header=TRUE, check.names= FALSE, textConnection("
A B x y
1 1 2 762920 1872674
2 2 3 778202 1899896
3 3 5 746324 1859111
4 4 5 762920 1872674
5 5 6 762920 1872674
6 6 3 762920 1872674"))
g1 <- graph.data.frame(relations, directed=TRUE)
# fill vertex attributes with coordinates of the table 'relations'
for(i in 1:length(V(g1))){
for(j in 1:nrow(relations)){
if(V(g1)[i]$name==as.character(relations$A[j])){
V(g1)[i]$coordx <- relations$x[j]
V(g1)[i]$coordy <- relations$y[j]
}
}
}
list.vertex.attributes(g1)
# plot the spatialised graph
coords <- cbind(V(g1)$coordx, V(g1)$coordy)
id <- tkplot(g1)
tkplot.setcoords(id, coords)
tkplot.center(id)
tkplot.fit.to.screen(id)
Проблема в том, что coords
были преобразованы по сравнению с начальным:
> tkplot.getcoords(id)
[,1] [,2]
[1,] 762920 27222
[2,] 778202 0
[3,] 746324 40785
[4,] 762920 27222
[5,] 762920 27222
[6,] 762920 27222
Очевидно, что 2-й столбец координат был "центрирован" по 0. Узел появляется в правом нижнем углу tk
окно.
0 ответов
Возможно, попробуйте исходные значения:
coords <- cbind(relations$x, relations$y)
а затем строить как обычно
id <- tkplot(g1)
tkplot.setcoords(id, coords)
tkplot.center(id)
tkplot.fit.to.screen(id)