我正在尝试使用rayshader包函数render_label呈现文本。
以WGS84 UTM表示的栅格:
localtif = raster::raster("G:\\My Drive\\Dem_12m.tif")标高矩阵:
elmat = matrix(raster::extract(localtif,raster::extent(localtif),buffer=1000),
nrow=ncol(localtif),ncol=nrow(localtif))我的rgl渲染:
elmat %>%
sphere_shade(texture = "desert") %>%
add_water(detect_water(elmat), color="desert") %>%
add_shadow(ray_shade(elmat,zscale=3,maxsearch = 300),0.5) %>%
add_shadow(ambmat,0.5) %>%
plot_3d(elmat,zscale=10,fov=0,theta=135,zoom=0.75,phi=45, windowsize = c(1000,800))从x和y获取行号和列号:
xy<-rowColFromCell(localtif, extract(localtif,SpatialPoints(cbind( 678349.471, 9197957.733)), cellnumbers=TRUE)[1])渲染文本:
render_label(elmat,x=xy[2],y=xy[1], z=4000,zscale=50,
text = "El Pico del Diablo",textsize = 10,linewidth = 5, freetype = F)文本似乎出现在DEM模型中的错误位置。我得到了这些xy值:
> xy
row col
[1,] 611 278 使用试错法,我发现正确的值是row = 180和col = 278。我还收到以下警告:
Warning message:
In rgl.texts(x = 278L, y = 103.72, z = -611L, text = "El Pico del Diablo", :
"bitmap" family only supports cex = 1发布于 2020-10-21 01:42:33
我也遇到了同样的问题,并找到了解决方案。
我对你的代码做了如下修改:
El_Pico_del_Diablo <- data.frame(lat= X.XX, long= -XX.XX) ###latitude and longitude in decimals. 在我的例子中,我的经度位置是负的。
elmat %>%
sphere_shade(texture = "desert") %>%
add_water(detect_water(elmat), color="desert") %>%
add_shadow(ray_shade(elmat,zscale=3,maxsearch = 300),0.5) %>%
add_shadow(ambmat,0.5) %>%
plot_3d(elmat,zscale=10,fov=0,theta=135,zoom=0.75,phi=45, windowsize = c(1000,800))
render_label(elmat, lat = El_Pico_del_Diablo$lat, long = El_Pico_del_Diablo$long,
extent = attr(localtif, "extent"),
altitude=100, zscale=10, text = "El Pico del Diablo",freetype=F, textsize = 5)https://stackoverflow.com/questions/54496653
复制相似问题