Changeset 2852 in lmdz_wrf for trunk/tools


Ignore:
Timestamp:
Feb 23, 2021, 1:21:52 PM (4 years ago)
Author:
lfita
Message:

Adding possibility of plot without color legend and '*' for no label in legend fot each box

Location:
trunk/tools
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/tools/drawing.py

    r2775 r2852  
    1131611316          [fontsize]: font size for the legend (auto for 12)
    1131711317          [Ncol]: number of columns (1)
    11318         labels: labels to write in the graph ('!' for spaces)
     11318        labels: labels to write in the graph ('!' for spaces, '*' for no label)
    1131911319        boxlvals: [line style]|[line width] values for the boxes (['-', 3], auto)
    1132011320        [ColorLeg] = [ijstart, orientation, labsize, sqsize, labrotation,
     
    1144211442        Boxlvals = ['-', 3]
    1144311443
    11444     if ColorLeg != 'auto':
    11445         colorleg = [np.float(ColorLeg.split('|')[0]), ColorLeg.split('|')[1],        \
    11446           np.float(ColorLeg.split('|')[2]), np.float(ColorLeg.split('|')[3]),        \
    11447           np.float(ColorLeg.split('|')[4]), np.float(ColorLeg.split('|')[5]),        \
    11448           np.float(ColorLeg.split('|')[6]), ColorLeg.split('|')[7]]
    11449     else:
    11450         colorleg = [0.8, 'vertical', 10., 10., 0., 0.8, 0.1, '#CCCCFF']
     11444    if ColorLeg == 'None':
     11445        colorleg = [None]*7 + ['#CCCCFF']
     11446    else:
     11447        if ColorLeg != 'auto':
     11448            colorleg = [np.float(ColorLeg.split('|')[0]), ColorLeg.split('|')[1],    \
     11449              np.float(ColorLeg.split('|')[2]), np.float(ColorLeg.split('|')[3]),    \
     11450              np.float(ColorLeg.split('|')[4]), np.float(ColorLeg.split('|')[5]),    \
     11451              np.float(ColorLeg.split('|')[6]), ColorLeg.split('|')[7]]
     11452        else:
     11453            colorleg = [0.8, 'vertical', 10., 10., 0., 0.8, 0.1, '#CCCCFF']
    1145111454
    1145211455    if mervals != 'auto':
  • trunk/tools/drawing_tools.py

    r2848 r2852  
    27312731    # Trimming figures
    27322732    # FROM: https://stackoverflow.com/questions/3130072/matplotlib-savefig-image-trim
    2733     plt.tight_layout()
     2733    #plt.tight_layout()
    27342734
    27352735    if close:
     
    1463114631      landseamask= landseamask values of the first domain
    1463214632      boxesX/Y= 4-line sets to draw the boxes
    14633       boxlabels= labels for the legend of the boxes
     14633      boxlabels= labels for the legend of the boxes ('*' for no label)
    1463414634      o[lon/lat]= longitude and latitude objects
    1463514635      lonlatLims: limits of longitudes and latitudes [lonmin, latmin, lonmax, latmax]
     
    1475314753        bbcol = gen.modify_color(cols[ibox], 'hex', 32, 'darken')
    1475414754        ix, iy = m(boxesX[ibox*4], boxesY[ibox*4])
    14755         plt.plot(ix, iy, linestyle=boxlvals[0], linewidth=boxlvals[1], color=bbcol,  \
    14756           label=gen.latex_text(boxlabels[ibox].replace('!',' ')))
     14755        if boxlabels[ibox] != '*':
     14756            plt.plot(ix, iy, linestyle=boxlvals[0], linewidth=boxlvals[1],           \
     14757              color=bbcol, label=gen.latex_text(boxlabels[ibox].replace('!',' ')))
    1475714758        ix, iy = m(boxesX[ibox*4+1], boxesY[ibox*4+1])
    1475814759        plt.plot(ix, iy, linestyle=boxlvals[0], linewidth=boxlvals[1], color=bbcol)
     
    1478014781    X, Y = fig.get_dpi() * fig.get_size_inches()
    1478114782
    14782     # Dimensions of the color-legend
    14783     totboxlength = legcolv[5]
    14784     ibox = legcolv[6]
    14785 
    14786     cbox = unichr(9632)#+unichr(9632)+unichr(9632)
    14787     bbox = unichr(9633)
    14788 
    14789     ccs = np.arange(0.,totboxlength,totboxlength/(nrows+1))
    14790 
    14791     iix = legcolv[0]
    14792     Ns = []
    14793     Cs = []
    14794     Xs = []
    14795     Ys = []
    14796     if legcolv[1] == 'vertical':
    14797         bw = totboxlength / (nrows + 1)
    14798         bh = bw * X / Y
    14799         Ns.append('> ' + str(topobnds[Ncolors-2]))
    14800         Cs.append(Ncolors-2)
    14801         Xs.append([iix,iix-bh])
    14802         Ys.append(ibox - ccs[0])
    14803         for i in range(1,Ncolors-2):
    14804             Ns.append(str(topobnds[Ncolors-2-i]))
    14805             Cs.append(Ncolors-2-i)
     14783    if legcolv[0] is not None:
     14784        # Dimensions of the color-legend
     14785        totboxlength = legcolv[5]
     14786        ibox = legcolv[6]
     14787
     14788        cbox = unichr(9632)#+unichr(9632)+unichr(9632)
     14789        bbox = unichr(9633)
     14790
     14791        ccs = np.arange(0.,totboxlength,totboxlength/(nrows+1))
     14792
     14793        iix = legcolv[0]
     14794        Ns = []
     14795        Cs = []
     14796        Xs = []
     14797        Ys = []
     14798        if legcolv[1] == 'vertical':
     14799            bw = totboxlength / (nrows + 1)
     14800            bh = bw * X / Y
     14801            Ns.append('> ' + str(topobnds[Ncolors-2]))
     14802            Cs.append(Ncolors-2)
    1480614803            Xs.append([iix,iix-bh])
    14807             Ys.append(ibox - ccs[i])
    14808         Ns.append('< 0')
    14809         Cs.append(0)
    14810         Xs.append([iix,iix-bh])
    14811         Ys.append(ibox - ccs[Ncolors-2])
    14812 
    14813     elif legcolv[1] == 'horizontal':
    14814         bw = totboxlength / (nrows + 1)
    14815         bh = bw * Y / X
    14816 
    14817         Ns.append('< 0')
    14818         Cs.append(0)
    14819         Xs.append(ibox+ccs[0])
    14820         Ys.append([iix-bh,iix])
    14821         for i in range(1,Ncolors-2):
    14822             Ns.append(str(topobnds[i]))
    14823             Cs.append(i)
    14824             Xs.append(ibox + ccs[i])
     14804            Ys.append(ibox - ccs[0])
     14805            for i in range(1,Ncolors-2):
     14806                Ns.append(str(topobnds[Ncolors-2-i]))
     14807                Cs.append(Ncolors-2-i)
     14808                Xs.append([iix,iix-bh])
     14809                Ys.append(ibox - ccs[i])
     14810            Ns.append('< 0')
     14811            Cs.append(0)
     14812            Xs.append([iix,iix-bh])
     14813            Ys.append(ibox - ccs[Ncolors-2])
     14814
     14815        elif legcolv[1] == 'horizontal':
     14816            bw = totboxlength / (nrows + 1)
     14817            bh = bw * Y / X
     14818
     14819            Ns.append('< 0')
     14820            Cs.append(0)
     14821            Xs.append(ibox+ccs[0])
    1482514822            Ys.append([iix-bh,iix])
    14826         Ns.append('> ' + str(topobnds[Ncolors-2]))
    14827         Cs.append(Ncolors-2)
    14828         Xs.append(ibox + ccs[Ncolors-2])
    14829         Ys.append([iix-bh,iix])
    14830     else:
    14831         print errormsg
    14832         print '  ' + fname + ": oritnation of legend of colors of topography " +     \
    14833           "scale '" + legcolv[1] + "' not ready !!"
    14834         print '    available ones:', availor
    14835         quit(-1)
    14836 
    14837     for ib in range(0,Ncolors-1):
    14838         Nb = Ns[ib]
    14839         if legcolv[1] == 'vertical':
    14840             ix = Xs[ib][0]
    14841             iy = Ys[ib]
    14842         elif legcolv[1] == 'horizontal':
    14843             ix = Xs[ib]
    14844             iy = Ys[ib][0]
    14845         plt.annotate(Nb, xy=(ix,iy), xycoords='figure fraction', fontsize=legcolv[2],\
    14846           rotation=legcolv[4])
    14847         if legcolv[1] == 'vertical':
    14848             ix = Xs[ib][1]
    14849         elif legcolv[1] == 'horizontal':
    14850             iy = Ys[ib][1]
    14851         plt.annotate(cbox, xy=(ix,iy), xycoords='figure fraction',                   \
    14852           fontsize=legcolv[3], color=HEXtopocolors[Cs[ib]])
    14853         plt.annotate(bbox, xy=(ix,iy), xycoords='figure fraction',                   \
    14854           fontsize=legcolv[3], color='k')
     14823            for i in range(1,Ncolors-2):
     14824                Ns.append(str(topobnds[i]))
     14825                Cs.append(i)
     14826                Xs.append(ibox + ccs[i])
     14827                Ys.append([iix-bh,iix])
     14828            Ns.append('> ' + str(topobnds[Ncolors-2]))
     14829            Cs.append(Ncolors-2)
     14830            Xs.append(ibox + ccs[Ncolors-2])
     14831            Ys.append([iix-bh,iix])
     14832        else:
     14833            print errormsg
     14834            print '  ' + fname + ": oritnation of legend of colors of topography " + \
     14835              "scale '" + legcolv[1] + "' not ready !!"
     14836            print '    available ones:', availor
     14837            quit(-1)
     14838
     14839        for ib in range(0,Ncolors-1):
     14840            Nb = Ns[ib]
     14841            if legcolv[1] == 'vertical':
     14842                ix = Xs[ib][0]
     14843                iy = Ys[ib]
     14844            elif legcolv[1] == 'horizontal':
     14845                ix = Xs[ib]
     14846                iy = Ys[ib][0]
     14847            plt.annotate(Nb, xy=(ix,iy), xycoords='figure fraction',                 \
     14848              fontsize=legcolv[2], rotation=legcolv[4])
     14849            if legcolv[1] == 'vertical':
     14850                ix = Xs[ib][1]
     14851            elif legcolv[1] == 'horizontal':
     14852                iy = Ys[ib][1]
     14853            plt.annotate(cbox, xy=(ix,iy), xycoords='figure fraction',               \
     14854              fontsize=legcolv[3], color=HEXtopocolors[Cs[ib]])
     14855            plt.annotate(bbox, xy=(ix,iy), xycoords='figure fraction',               \
     14856              fontsize=legcolv[3], color='k')
    1485514857
    1485614858    figname = 'plot_topofix_geogrid'
Note: See TracChangeset for help on using the changeset viewer.