【问题标题】:Python pcolormesh with separate alpha value for each binPython pcolormesh,每个 bin 都有单独的 alpha 值
【发布时间】:2020-11-03 03:56:01
【问题描述】:

假设我有以下数据集:

import numpy as np
import matplotlib.pyplot as plt

x_bins = np.arange(10)
y_bins = np.arange(10)
z = np.random.random((9,9))

我可以轻松地绘制这些数据

plt.pcolormesh(x_bins, y_bins, z, cmap = 'viridis)

但是,假设我现在为每个点添加一些 alpha 值:

a = np.random.random((9,9))

如何更改 pcolormesh 图中每个框的 alpha 值以匹配数组“a”中的相应值?

【问题讨论】:

    标签: python matplotlib alpha


    【解决方案1】:

    pcolormesh 创建的网格只能有一个完整网格的 alpha。要为每个单元格设置单独的 alpha,需要将单元格一个一个地创建为矩形。

    下面的代码在左侧显示了没有 alpha 的 pcolormesh,在右侧显示了带有 alpha 的矩形网格。请注意,在矩形接触的点上,半透明会导致一些不相等的重叠。这可以通过不绘制单元格边缘 (edgecolor='none') 或使用更长的黑线来分隔单元格来缓解。

    下面的代码更改了 x 维度,因此更容易验证 xy 没有混淆。 relimautoscale 是必需的,因为 matplotlib 的默认行为不会通过添加补丁来更改 x 和 y 限制。

    import numpy as np
    import matplotlib.pyplot as plt
    from matplotlib.patches import Rectangle, Patch
    
    x_bins = np.arange(12)
    y_bins = np.arange(10)
    z = np.random.random((9, 11))
    a = np.random.random((9, 11))
    
    cmap = plt.get_cmap('inferno')
    norm = plt.Normalize(z.min(), z.max())
    
    fig, (ax1, ax2) = plt.subplots(ncols=2)
    ax1.pcolormesh(x_bins, y_bins, z, cmap=cmap, norm=norm)
    for i in range(len(x_bins) - 1):
        for j in range(len(y_bins) - 1):
            rect = Rectangle((x_bins[i], y_bins[j]), x_bins[i + 1] - x_bins[i], y_bins[j + 1] - y_bins[j],
                             facecolor=cmap(norm(z[j, i])), alpha=a[j, i], edgecolor='none')
            ax2.add_patch(rect)
    # ax2.vlines(x_bins, y_bins.min(), y_bins.max(), edgecolor='black')
    # ax2.hlines(y_bins, x_bins.min(), x_bins.max(), edgecolor='black')
    ax2.relim()
    ax2.autoscale(enable=True, tight=True)
    
    plt.show()
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-10-29
      • 1970-01-01
      • 2021-12-23
      • 1970-01-01
      • 1970-01-01
      • 2015-11-12
      相关资源
      最近更新 更多