R/legdiscrete.R

Defines functions discreteleg

#'Create discrete legend for plotting 
#'
#'@inputdf=input data frame
#'@ntiles=number of desired categories
#'@colname=column name in the dataframe
#'@inraster=if the input is a raster give raster name
#'

discreteleg<- function(inputdf, ntiles, colname, inraster = NULL) {
    if (!is.null(inraster)) {
        griddf <- data.frame(coordinates(inraster), as.data.frame(inraster))
        griddf <- na.exclude(griddf)
        colnames(griddf)[3] <- c("cat")
        inputdf <- merge(griddf, inputdf, all.x = T)
    }
    nas <- inputdf[is.na(inputdf[, colname]), ]
    inputdf1 <- inputdf[!is.na(inputdf[, colname]), ]
    inputdf1$rank <- ntile(inputdf1[, colname], n = ntiles)
    inputdf1 <- orderBy(~rank, data = inputdf1)
    rank.l <- unique(inputdf1$rank)
    results <- NULL
    for (i in 1:length(rank.l)) {
        tmp <- subset(inputdf1, rank == rank.l[i])
        labminmax1 <- paste("[", round(min(tmp[, colname]), digits = 2), ";",round(max(tmp[,colname]), digits = 2), "]", sep = "")
        tmp$rankd <- labminmax1
        results <- rbind(tmp, results)        
    }
    results$rankd <- as.factor(results$rankd)
    nas$rank <- NA
    nas$rankd <- NA
    results1 <- rbind(results, nas)
    return(results1)
}
marcog77/marcoUtils documentation built on Sept. 11, 2019, 4:05 a.m.