在图片上绘制 seaborn 热力图代码

# 定义从白色到黑色的颜色梯度
colors = ["white", "black"]
cmap_name = "white_black"
n_bins = 4  # 定义梯度中的颜色数量

# 创建LinearSegmentedColormap对象
white_black_cmap = LinearSegmentedColormap.from_list(cmap_name, colors, N=n_bins)
# 假设你有一张128x128的图像文件
image_path = f"save/im{i}.png"  # 替换为你的图像文件路径
image = Image.open(image_path)
# image = image.resize((128, 128))  # 确保图像是128x128大小

data = 生成一个和 image 一样大的数据, 如 128x128

# 设置图形的风格为白色背景
sns.set_theme(style="white")

# 创建一个matplotlib的图和坐标轴对象
fig, ax = plt.subplots(figsize=(10, 8))

# 首先绘制底层图像
ax.imshow(image, extent=[0, 128, 0, 128], origin="lower")

# 然后叠加热力图,通过设置alpha参数来调整透明度
sns.heatmap(data, cmap=white_black_cmap, alpha=0.6, ax=ax, cbar=False, zorder=2)

# 移除坐标轴的刻度标签
ax.set_xticks([])
ax.set_yticks([])

# 设置标题
# ax.set_title('Overlay Heatmap on Image', fontsize=20, pad=20)

# 显示图形
# plt.show()
plt.savefig(f"save/hwadd{i}.pdf", format="pdf", bbox_inches="tight", pad_inches=0.0)

效果如下,上边的 cmap 可以改,也提供了自定义cmap的部分
在这里插入图片描述

  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值