fmt
ไม่มีส่วนเกี่ยวข้องกับการเว้นวรรคของรายการในตำนาน สำหรับรายละเอียดของfmt
โปรดดูที่การใช้ C-String สไตล์การจัดรูปแบบคำสั่ง เพียงวางข้อมูลโค้ดต่อไปนี้ในR
คอนโซลของคุณเพื่อดูความแตกต่าง (pi ~ 3.14):
sprintf("%f", pi)
sprintf("%.3f", pi)
sprintf("%1.0f", pi)
sprintf("%5.1f", pi)
sprintf("%05.1f", pi)
sprintf("%+f", pi)
sprintf("% f", pi)
sprintf("%-10f", pi) # left justified
sprintf("%e", pi)
sprintf("%E", pi)
sprintf("%g", pi)
sprintf("%g", 1e6 * pi) # -> exponential
sprintf("%.9g", 1e6 * pi) # -> "fixed"
sprintf("%G", 1e-6 * pi)
choro.legend()
โทรlegend()
ภายใน เพื่อลดระยะห่างแนวนอนระหว่างรายการคำอธิบายคุณควรเปลี่ยนtext.width
พารามิเตอร์ของlegend()
ฟังก์ชัน น่าเสียดายที่choro.legend
ไม่มีพารามิเตอร์ในการตั้งค่าtext.width
ภายนอกให้คำนวณจากภายใน ฉันเพิ่มspace_reduction
พารามิเตอร์ลงในchoro.legend
และปรับเปลี่ยนฟังก์ชั่นเดิมเล็กน้อยดังนี้
choro.legend <- function (px, py, sh, under = "under", over = "over", between = "to",
fmt = "%g", cex = 1, space_reduction = 0, ...)
{
x = sh$breaks
lx = length(x)
if (lx < 3)
stop("break vector too short")
res = character(lx + 1)
res[1] = paste(under, sprintf(fmt, x[1]))
for (i in 1:(lx - 1)) res[i + 1] <- paste(sprintf(fmt, x[i]),
between, sprintf(fmt, x[i + 1]))
res[lx + 1] <- paste(over, sprintf(fmt, x[lx]))
maxwidth <- max(strwidth(res)) - space_reduction
temp <- legend(x = px, y = py, legend = rep(" ", length(res)),
fill = sh$cols, text.width = maxwidth, cex = cex, ...)
text(temp$rect$left + temp$rect$w, temp$text$y, res, pos = 2,
cex = cex)
}
บันทึกตัวอย่างนี้ในไฟล์สคริปต์ R และsource
มัน ข้อมูลโค้ดที่ทำซ้ำได้จะเป็นดังนี้:
library(GISTools)
data(newhaven)
blocks
val <- blocks@data$POP1990
shade <- auto.shading(val)
choropleth(blocks, v= val, shade)
choro.legend(514000, 175000,shade,title='My Legend',cex=.8, bty = "n", fmt = "%0.0f",
space_reduction=4000)
ค่อยๆลด / เพิ่มspace_reduction
พารามิเตอร์เพื่อให้ได้ผลลัพธ์ตามที่ต้องการ