【python海洋专题十一】colormap调色

news2025/1/6 20:28:36

【python海洋专题十一】colormap调色

上期内容

在这里插入图片描述

本期内容

图像的函数包调用!

Part01.

自带颜色条Colormap

调用方法:

cmap3=plt.get_cmap('ocean')

在这里插入图片描述
查询方法!
在这里插入图片描述在这里插入图片描述

Part02.

seaborn函数包

01:sns.cubehelix_palette

cmap5= sns.cubehelix_palette(10, start=1.5, rot=0, dark=0.05, light=.95, gamma=0.5, reverse=True, as_cmap=True)

参数rot控制在调色板的范围内围绕色调轮旋转

参数start控制螺旋线开始的色调

没有发现可循的规律

参数gamma控制颜色的明暗、越小于1越亮、越大于1越暗;

使用的时候慢慢调整到合适的、所需要的颜色吧!

02:sns.dark_palette

cmap6=  sns.dark_palette("gray", n_colors=6, reverse=False, as_cmap=True, input='rgb')

制作一个混合深色和 color 模式的顺序调色板。

范围从相对低值(不感兴趣)到相对高值(很感兴趣)时。

color:高值的基色;

n_colors:int, 调色板中的颜色数。

input:{‘rgb’, ‘hls’, ‘husl’, xkcd’}

用于解释输入颜色的颜色空间。前三个选项适用于元组输入,后者适用于字符串输入。

03:sns.diverging_palette

cmap = sns.diverging_palette(200, 20, as_cmap=True)

h_neg, h_pos 起始/终止颜色值

s 饱和度, 0-100

l 亮度, 0-100

n 颜色个数

center 中心颜色 light(默认), dark

as_cmap 返回一个 matplotlib colormap 而不是一个颜色列表。

04:sns的全部都可应用

使用方法:

cmap=ListedColormap(sns.color_palette("bright"))

05:可以直接设置:

cmap="Oranges";
cmap="Blues";
cmap="Greens";
cmap="Reds";
cmap="Purples";
cmap="Greys";
等其他色系:cmap="RdBu";

在这里插入图片描述
在这里插入图片描述

Part03.

palettable函数包

from palettable.scientific.diverging import Roma_20
cmap02=Roma_20.mpl_colormap

在这里插入图片描述

颜色共有:1587种类。

小编已经将palettable的1587种Colormap精心整理成为“51页高清pdf”文件

提取链接:

链接:https://pan.baidu.com/s/111ME6sHeQJbty4-YZsgysA 提取码:u4m4

来源:

调色板界的“扛把子”–palettable - 知乎 (zhihu.com)

全文代码

# -*- coding: utf-8 -*-
# %%
# Importing related function packages
import matplotlib.pyplot as plt
import cartopy.crs as ccrs
import cartopy.feature as feature
import numpy as np
import matplotlib.ticker as ticker
from cartopy import mpl
from cartopy.mpl.ticker import LongitudeFormatter, LatitudeFormatter
from cartopy.mpl.gridliner import LONGITUDE_FORMATTER, LATITUDE_FORMATTER
from matplotlib.font_manager import FontProperties
from netCDF4 import Dataset
import palettable
from palettable.cmocean.diverging import Delta_4
from palettable.colorbrewer.sequential import GnBu_9
from palettable.colorbrewer.sequential import Blues_9
from palettable.scientific.diverging import Roma_20
from palettable.cmocean.diverging import Delta_20
from palettable.scientific.diverging import Roma_20
from matplotlib.colors import ListedColormap
from pylab import *
import seaborn as sns
from matplotlib import cm
def reverse_colourmap(cmap, name='my_cmap_r'):
    reverse = []
    k = []
    for key in cmap._segmentdata:
        k.append(key)
        channel = cmap._segmentdata[key]
        data = []
        for t in channel:
            data.append((1 - t[0], t[2], t[1]))
        reverse.append(sorted(data))
    LinearL = dict(zip(k, reverse))
    my_cmap_r = mpl.colors.LinearSegmentedColormap(name, LinearL)
    return my_cmap_r
# -------------%------------
cmap01=Delta_20.mpl_colormap
cmap02=Roma_20.mpl_colormap
cmap03=ListedColormap(sns.color_palette("bright"))
cmap04=ListedColormap(sns.color_palette("Spectral", 10))
cmap05=ListedColormap(sns.color_palette("RdYlBu", 1000))
#cmap05=ListedColormap(sns.color_palette("Blues_r", 1000)[0:700])

cmap = Blues_9.mpl_colormap
cmap_r = reverse_colourmap(cmap)
cmap1 = GnBu_9.mpl_colormap
cmap_r1 = reverse_colourmap(cmap1)
cmap2 = Roma_20.mpl_colormap
cmap_r2 = reverse_colourmap(cmap2)
cmap3=plt.get_cmap('ocean')
cmap3_r3=plt.get_cmap('terrain')
cmap4=plt.get_cmap('gist_earth')
#cmap51 = sns.cubehelix_palette(light=1, as_cmap=True)
cmap5= sns.cubehelix_palette(10, start=2, rot=0, dark=0.05, light=.95, gamma=0.5, reverse=True, as_cmap=True)
cmap6= sns.dark_palette("gray", n_colors=6, reverse=False, as_cmap=True, input='rgb')
cmap7= sns.diverging_palette(100, 50, as_cmap=True)
# -------------# read data------------
a = Dataset('D:\pycharm_work\data\scs_etopo.nc')
print(a)
lon = a.variables['lon'][:]
lat = a.variables['lat'][:]
ele = a.variables['elevation'][:]
# -------------# plot ------------
scale = '50m'
plt.rcParams['font.sans-serif'] = ['Times New Roman']  # 设置整体的字体为Times New Roman
fig = plt.figure(dpi=300, figsize=(3, 2), facecolor='w', edgecolor='blue')#设置一个画板,将其返还给fig
ax = fig.add_axes([0.05, 0.08, 0.92, 0.8], projection=ccrs.PlateCarree(central_longitude=180))
ax.set_extent([105, 125, 0, 25], crs=ccrs.PlateCarree())# 设置显示范围
land = feature.NaturalEarthFeature('physical', 'land', scale, edgecolor='face',
                                    facecolor=feature.COLORS['land'])
ax.add_feature(land, facecolor='0.6')
ax.add_feature(feature.COASTLINE.with_scale('50m'), lw=0.3)#添加海岸线:关键字lw设置线宽;linestyle设置线型
cs = ax.contourf(lon, lat, ele[:, :], levels=np.arange(-7000,0,20),extend='both',cmap=cmap05, transform=ccrs.PlateCarree())
# ------colorbar设置
cb = plt.colorbar(cs, ax=ax, extend='both', orientation='vertical',ticks=np.linspace(-7000, 0, 7))
cb.set_label('depth', fontsize=4, color='k')#设置colorbar的标签字体及其大小
cb.ax.tick_params(labelsize=4, direction='in') #设置colorbar刻度字体大小。
#cf = ax.contour(lon, lat, ele[:, :], levels=[-5000,-2000,-500,-300,-100,-50],colors='gray', linestyles='-',
 #                   linewidths=0.2,transform=ccrs.PlateCarree())
# 添加标题
ax.set_title('Etopo', fontsize=4)
# 利用Formatter格式化刻度标签
ax.set_xticks(np.arange(107, 125, 4), crs=ccrs.PlateCarree())#添加经纬度
ax.set_xticklabels(np.arange(107, 125, 4), fontsize=4)
ax.set_yticks(np.arange(0, 25, 2), crs=ccrs.PlateCarree())
ax.set_yticklabels(np.arange(0, 25, 2), fontsize=4)
ax.xaxis.set_major_formatter(LongitudeFormatter())
ax.yaxis.set_major_formatter(LatitudeFormatter())
ax.tick_params(color='k', direction='in')#更改刻度指向为朝内,颜色设置为蓝色
gl = ax.gridlines(crs=ccrs.PlateCarree(), draw_labels=False, xlocs=np.arange(107, 125, 4), ylocs=np.arange(0, 25, 2),
        linewidth=0.25, linestyle='--', color='k', alpha=0.8)#添加网格线
gl.top_labels, gl.bottom_labels, gl.right_labels, gl.left_labels = False, False, False, False
plt.savefig('scs_elevation06.jpg', dpi=600, bbox_inches='tight', pad_inches=0.1)  # 输出地图,并设置边框空白紧密
plt.show()

参考文献

图片
1:Python可视化|matplotlib07-自带颜色条Colormap(三) - 知乎 (zhihu.com)

2:164种默认colormap样式【附图】_colormap种类-CSDN博客

3:Python 画图常用颜色 - 单色、渐变色、混色 - 够用_puthon 颜色渐变-CSDN博客

4:通过函数seaborn.cubehelix_palette生成顺序调色板_sns.cubehelix_palette-CSDN博客

5:seaborn调色板 color, hls, cubehelix, dark, diverging_palette_sns.diverging_palette-CSDN博客

6:python画图配色总结_python配色_我的心永远是冰冰哒的博客-CSDN博客

7:调色板界的“扛把子”–palettable - 知乎 (zhihu.com)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1062695.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【MySQL】错误1166 Incorrect column name

错误1166 Incorrect column name 是指字段名里有空格 Incorrect column name ‘name’ 图中报错的原因是name字段中有空格 删除空格即可

基于SpringBoot的视频网站系统

目录 前言 一、技术栈 二、系统功能介绍 用户信息管理 视频分享管理 视频排名管理 交流论坛管理 留言板管理 三、核心代码 1、登录模块 2、文件上传模块 3、代码封装 前言 使用旧方法对视频信息进行系统化管理已经不再让人们信赖了,把现在的网络信息技术运…

ParagonNTFSforMac_15.5.102中文版最受欢迎的NTFS硬盘格式读取工具

Paragon NTFS for Mac是一款可以为您轻松解决Mac平台上不能识别Windows通用的NTFS文件难题,这是一款强大的Mac读写工具,相信在很多时候,Mac用户需要对NTFS文件的移动硬盘进行写入,但是macOS系统默认是不让写入的,使用小…

妙不可言的Python之旅----(二)

Python基础语法 什么是字面量 字面量:在代码中,被写下来的的固定的值,称之为字面量 常用的值类型 类型 描述 说明 数字(Number) 支持 • 整数(int) • 浮点数(float&#xff…

C++基础知识(二) -- 函数重载

自然语言中,一个词可以有多重含义,人们可以通过上下文来判断该词真实的含义,即该词被重载了。 比如:以前有一个笑话,国有两个体育项目大家根本不用看,也不用担心。一个是乒乓球,一个是男足。前者…

如何禁用Windows 10快速启动(以及为什么要这样做)

如果您不想启用Windows 10快速启动,则可以相对轻松地禁用它。 快速启动是一项功能,首先在 Windows 8 中作为快速启动实现,并延续到 Windows 10,让您的 PC 更快地启动,因此得名。虽然这个方便的功能可以通过将操作系统…

Qt model/view 理解01

在 Qt 中对数据处理主要有两种方式:1)直接对包含数据的的数据项 item 进行操作,这种方法简单、易操作,现实方式单一的缺点,特别是对于大数据或在不同位置重复出现的数据必须依次对其进行操作,如果现实方式改…

了解基于Elasticsearch 的站内搜索,及其替代方案

对于一家公司而言,数据量越来越多,如果快速去查找这些信息是一个很难的问题,在计算机领域有一个专门的领域IR(Information Retrival)研究如何获取信息,做信息检索。在国内的如百度这样的搜索引擎也属于这个…

Linux系统编程系列之线程池

Linux系统编程系列(16篇管饱,吃货都投降了!) 1、Linux系统编程系列之进程基础 2、Linux系统编程系列之进程间通信(IPC)-信号 3、Linux系统编程系列之进程间通信(IPC)-管道 4、Linux系统编程系列之进程间通信-IPC对象 5、Linux系统…

Linux文件查找、别名、用户组

1、文件查看: 查看/etc/passwd文件的第5行 2、文件查找 (1)在当前目录及子目录中,查找大写字母开头的txt文件 (2)在/etc及其子目录中,查找以数字开头的文件 (3)在$HOME目录及其子目录中,查找所有文本文件 (4)忽略文件名大小写查找a.txt 3、查…

博途1200/1500 ALT指令

SMART PLC的ALT指令实现代码,请查看下面文章博客 SMART PLC如何构造ALT指令_smart200类似alt指令-CSDN博客单按钮启停这些老生常谈的问题,很多人感兴趣。这篇博文讨论下不同的实现方法,希望对大家有所帮助。指令虽然简单,但是在编程的时候合理使用对我们高效率编程帮助还是…

来聊一聊独热码检测

国庆假期不小心扭伤了脚踝,在家没事看到一篇文章挺有意思,于是写出来分享给大家。 这是一道数字电路面试题,也是很多面试官很喜欢考察面试者的一道题目,题干很简单:给定一个4bit的信号A,设计逻辑来判断A是…

博客之站项目测试报告

项目背景项目功能测试计划Bug总结升级自动化测试正常登录流程 项目背景 1:博客之站系统是采用前后端分离的方式来实现;使用MySQL、Redis数据库储存相关数据;同时部署到云服务器上。 2:包含注册页、登录页、博客列表页、个人列表页…

计算机考研 | 2020年 | 计算机组成原理真题

文章目录 【计算机组成原理2020年真题43题-13分】【第一步:信息提取】【第二步:具体解答】 【计算机组成原理2020年真题44题-10分】【第一步:信息提取】【第二步:具体解答】 【计算机组成原理2020年真题43题-13分】 【第一步&…

vertx的学习总结6之动态代理类和测试

Beyond the event bus 一、章节覆盖: 如何在事件总线之上公开服务 verticles和事件总线服务的异步测试 动态代理: MyService 接口 package porxy.test;import io.vertx.codegen.annotations.ProxyGen;ProxyGen public interface MyService {void he…

基于ssm的电商管理平台/基于javaweb的网上购物系统/电子商城网站

摘 要 本文论述了电商管理平台的设计和实现,该网站从实际运用的角度出发,运用了计算机网站设计、数据库等相关知识,基于SSM框架、JSP技术和Mysql数据库设计来实现的,网站主要包括用户注册、用户登录、查看商品信息、系统公告等…

优化方法的应用(optimtool.example)

import optimtool as oo from optimtool.base import np, sp, pltpip install optimtool>2.4.2优化方法的应用(optimtool.example) import optimtool.example as oeLasso问题(Lasso) oe.Lasso.[函数名]([矩阵A], [矩阵b], [因…

Linux删除空目录/非空目录和文件

一、删除目录 删除名为mydir的空目录: rmdir mydir 删除名为mydir的非空目录(非空目录是指该目录包含了其他文件或子目录,而不是空的或没有任何内容的目录) rm -r mydir 删除mydir1下的空目录mydir2 rmdir mydir1/mydir2 删除当前目录下所有以dir一个数字结尾的目录…

打开MySQL数据库

在命令行里输入mysql --version就可以查看: mysql -uroot -p之前设置的密码(不用输入)就可登录成功:

什么是邮件签名证书?

邮件签名证书是一种数字证书,用于保护电子邮件的安全性和可信度。邮件签名证书可以确保电子邮件本身在发送过程中不会被篡改或伪造,同时也可以验证发件人的身份。 邮件签名证书的工作原理是使用S/MIME协议。S/MIME协议是一种用于加密和签名电子邮件的标准…