Nothing
export_projet_qgis_ronds_classes <-
function(liste_fonds,chemin_fonds,nom_projet,titre,titre2,sourc,titre_leg_classes,table_classe,variable_a_representer,annee)
{
chemin_fonds <- paste0(chemin_fonds,"/layers/")
fond_maille <- read_sf(paste0(chemin_fonds,"fond_maille.shp"))
xmin=st_bbox(fond_maille)[1]-0.10*(st_bbox(fond_maille)[3]-st_bbox(fond_maille)[1])
xmax=st_bbox(fond_maille)[3]+0.10*(st_bbox(fond_maille)[3]-st_bbox(fond_maille)[1])
ymin=st_bbox(fond_maille)[2]-0.10*(st_bbox(fond_maille)[4]-st_bbox(fond_maille)[2])
ymax=st_bbox(fond_maille)[4]+0.10*(st_bbox(fond_maille)[4]-st_bbox(fond_maille)[2])
#on reajuste la fenetre pour que (xmax-xmin)=1.65(ymax-ymin)
dif_x=xmax-xmin
dif_y=ymax-ymin
if (dif_x>dif_y)
{
if (dif_x/dif_y<1.65)
{
xmin=xmin-((1.65*dif_y-dif_x)/2)
xmax=xmax+((1.65*dif_y-dif_x)/2)
}else
{
ymin=ymin-((dif_x/1.65)-dif_y)/2
ymax=ymax+((dif_x/1.65)-dif_y)/2
}
}else
{
xmin=xmin-((1.65*dif_y-dif_x)/2)
xmax=xmax+((1.65*dif_y-dif_x)/2)
}
BLOCCOMPOSER=modif_canevas_MEP(nom_projet,str_sub(titre,end=-2),titre2,annee,sourc,xmin,xmax,ymin,ymax)
BLOCLEG=data.frame()
BLOCPROJECT=data.frame()
BLOCLAYERITEM=data.frame()
l <- liste_fonds
for (i in 1:length(l))
{
#BLOCLEG
if (nchar(l[i])<11)
{
idcouche=paste0(l[i],str_c(rep("0",11-nchar(l[i])), collapse = ""))
}else
{
idcouche=l[i]
}
toto=modif_blocleg(l[i],idcouche)
BLOCLEG=rbind(BLOCLEG,toto)
#BLOCLAYERITEM
if(str_sub(l[i][length(l[i])],start=-5)=="carte")
{
if(titre_leg_classes=="")
{
bloclayeritem=modif_bloclayeritem(variable_a_representer,idcouche,"subgroup")
}else
{
bloclayeritem=modif_bloclayeritem(titre_leg_classes,idcouche,"subgroup")
}
}else
{
bloclayeritem=modif_bloclayeritem(l[i],idcouche,"hidden")
}
#BLOCPROJECT
#param idcouche, chemincouche, nomcouche
nomcouche=l[i]
chemincouche=paste0(chemin_fonds,nomcouche,".shp")
chemincoucherelatif=paste0("./layers/",nomcouche,".shp")
BLOCCATEGORIES=data.frame()
#cas ou le fond selectionne est la carte ou la legende
if(str_sub(l[i][length(l[i])],start=-5)=="carte")
{
analyse_classes <- read_sf(chemincouche)
geometrie=attr(analyse_classes$geometry[[1]],"class")[2]
projcouche=st_crs(analyse_classes$geometry)$proj4string
attr="attr='classe'"
typeanalyse="categorizedSymbol"
BLOCSYMBOLS=data.frame()
BLOCCATEGORIES=data.frame(V1=" <categories>")
BLOCVECTOR=data.frame()
for(j in 1:dim(table_classe)[1])
{
#creer le bloc categories
symbol=name=as.character(j)
value=table_classe[j,1]
label=table_classe[j,2]
#value=label=table_classe[j,2]
temp=modif_bloccategories(symbol,value,label)
BLOCCATEGORIES=rbind(BLOCCATEGORIES,temp)
#creer autant de bloc symbols que de classes avec le bon canevas symbols
stylebordure="solid"
epaisseurbordure=0.26
couleurbordure=unique(analyse_classes$COL_BOR)
couleurfond=as.character(table_classe[j,3])
remplissagefond="solid"
temp=modif_blocsymbolsPolygon(couleurfond,couleurbordure,remplissagefond,stylebordure,epaisseurbordure,name)
BLOCSYMBOLS=rbind(BLOCSYMBOLS,temp)
#MEP
blocvector=modif_blocvectorClassification(table_classe[j,2])
blocvector=data.frame(V1=c(blocvector[1:2,],temp[,1],blocvector[4:5,]))
BLOCVECTOR=rbind(BLOCVECTOR,blocvector)
}
BLOCCATEGORIES=rbind(BLOCCATEGORIES,data.frame(V1=" </categories>"))
bloclayeritem=data.frame(V1=c(bloclayeritem[1,],BLOCVECTOR[,1],bloclayeritem[3,]))
BLOCLAYERITEM=rbind(BLOCLAYERITEM,bloclayeritem)
toto=modif_blocprojectlayers(geometrie,idcouche,chemincoucherelatif,nomcouche,projcouche,attr,typeanalyse)
toto=rbind(data.frame(V1=toto[1:13,]),BLOCCATEGORIES,data.frame(V1=toto[15,]),BLOCSYMBOLS,data.frame(V1=toto[17:23,]))
BLOCPROJECT=rbind(BLOCPROJECT,toto)
}else
{
#cas oC9 le fond selectionne n'est pas la carte ni la legende, ou legende saphir ou rond avec 2classes ou legende ronds qd typana=classes'
attr=""
name="0"
typeanalyse="singleSymbol"
couleurfond="255,255,255"
remplissagefond="no"
if (l[i] %in% c("fond_maille","fond_departement","fond_region","fond_pays","fond_etranger"))
{
couleurbordure="128,128,128"
}else if (l[i]=="fond_maille_elargi")
{
couleurbordure="200,200,200"
}else if (l[i]=="fond_territoire")
{
couleurbordure="191,191,191"
}else
{
couleurbordure="0,0,0"
}
stylebordure="solid"
if (l[i] %in% c("fond_maille","fond_maille_elargi","fond_departement","fond_pays","fond_etranger","fond_territoire"))
{
epaisseurbordure=0.26
}else
{
epaisseurbordure=0.5
}
fond <- read_sf(chemincouche)
projcouche=st_crs(fond)$proj4string
geometrie=attr(fond$geometry[[1]],"class")[2]
if(is.null(geometrie))
geometrie=attr(fond[[1]][[1]],"class")[2]
if(is.null(geometrie))
geometrie=attr(fond[[1]],"class")[2]
if (geometrie %in% c("POLYGON","MULTIPOLYGON"))
{
BLOCSYMBOLS=modif_blocsymbolsPolygon(couleurfond,couleurbordure,remplissagefond,stylebordure,epaisseurbordure,name)
}else
{
if (geometrie %in% c("MULTILINESTRING"))
{
BLOCSYMBOLS=modif_blocsymbolsLine(couleurbordure,stylebordure,epaisseurbordure,name)
}else
{#inutile??
BLOCSYMBOLS=balises_qgis()[[6]]
}
}
blocvector=modif_blocvectorClassification(nomcouche)
blocvector=data.frame(V1=c(blocvector[1:2,],BLOCSYMBOLS[,1],blocvector[4:5,]))
bloclayeritem=data.frame(V1=c(bloclayeritem[1,],blocvector[,1],bloclayeritem[3,]))
BLOCLAYERITEM=rbind(BLOCLAYERITEM,bloclayeritem)
if (l[i]=="fond_ronds_leg")
{
BLOCSYMBOLSGENERATOR <- balises_qgis()[[11]]
BLOCLABELING <- balises_qgis()[[12]]
}else
{
BLOCSYMBOLSGENERATOR <- data.frame()
BLOCLABELING <- data.frame()
}
toto=modif_blocprojectlayers(geometrie,idcouche,chemincoucherelatif,nomcouche,projcouche,attr,typeanalyse)
toto=rbind(data.frame(V1=toto[1:13,]),BLOCCATEGORIES,data.frame(V1=toto[15,]),data.frame(V1=BLOCSYMBOLS[1:11,]),BLOCSYMBOLSGENERATOR,data.frame(V1=BLOCSYMBOLS[12,]),data.frame(V1=toto[17:20,]),BLOCLABELING,data.frame(V1=toto[21:23,]))
BLOCPROJECT=rbind(BLOCPROJECT,toto)
}
}
projproj=projcouche
qgs1=modif_canevas(xmin,xmax,ymin,ymax,projproj,length(l))
#etape finale
blocproperties <- balises_qgis()[[13]]
BLOCCOMPOSER=data.frame(V1=c(BLOCCOMPOSER[1:43,],BLOCLAYERITEM[,1],BLOCCOMPOSER[45:94,]))
canevas_final=data.frame(V1=c(qgs1[1:19,],BLOCLEG[,1],qgs1[21,],BLOCCOMPOSER[,1],qgs1[23,],BLOCPROJECT[,1],qgs1[25,],blocproperties[,1],qgs1[26,]))
colnames(canevas_final)=NULL
write.csv(canevas_final,paste0(substr(chemin_fonds,1,nchar(chemin_fonds)-7),nom_projet,".qgs"),row.names = F, quote = F, fileEncoding = "UTF-8")
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.