Я нашел решение, оно сложное, но если у вас есть какой-то другой вариант, который лучше моего, я оставлю эту топику c открытой.
Я создаю поддельную тепловую карту с тем же размером, что и первый, но я поместил свой диапазон в поддельную карту тепла. так вот код:
x_number_list = df.X.tolist()
y_number_list = df.Y.tolist()
x_number_list = np.array(x_number_list)
y_number_list = np.array(y_number_list)
area_number_list = df.area.tolist()
area_number_list = [int(round(x+1,0)) for x in area_number_list]
temperature_number_list = df.temp.tolist()
temperature_number_list = np.array(temperature_number_list)
heatmap, xedges, yedges = np.histogram2d(y_number_list, x_number_list, weights=temperature_number_list)
#create fake heatmap
colorbar_parameter_by_temperature = []
for i in range(len(heatmap)):
colorbar_parameter_by_temperature.append([0]*len(heatmap[0]))
colorbar_parameter_by_temperature[i][0]=temperature_number_list.max()
colorbar_parameter_by_temperature[i][1]=temperature_number_list.min()
fig, ax1 = plt.subplots(figsize=(7,7))
#im = ax1.imshow(heatmap, interpolation='bicubic', cmap='hot', origin='lower') #bicubic
im2 = ax1.imshow(heatmap2, interpolation='spline16', cmap='hot', origin='lower')
im = ax1.imshow(heatmap, interpolation='spline16', cmap='hot', origin='lower')
ax1.scatter(x_number_list, y_number_list, s=area_number_list, color=(157/255, 173/255, 245/255, 0.9))
ax1.set_ylim(y_number_list.min()-0.5, y_number_list.max()+0.5)
ax1.set_xlim(x_number_list.min()-0.5, x_number_list.max()+0.5)
cb = plt.colorbar(im2, ax=ax1, shrink=0.73)
plt.show()
вот результат:
[[33.3, 2.2, 0, 0, 0, 0, 0, 0, 0, 0], [33.3, 2.2, 0, 0, 0, 0, 0, 0, 0, 0], [33.3, 2.2, 0, 0, 0, 0, 0, 0, 0, 0], [33.3, 2.2, 0, 0, 0, 0, 0, 0, 0, 0], [33.3, 2.2, 0, 0, 0, 0, 0, 0, 0, 0], [33.3, 2.2, 0, 0, 0, 0, 0, 0, 0, 0], [33.3, 2.2, 0, 0, 0, 0, 0, 0, 0, 0], [33.3, 2.2, 0, 0, 0, 0, 0, 0, 0, 0], [33.3, 2.2, 0, 0, 0, 0, 0, 0, 0, 0], [33.3, 2.2, 0, 0, 0, 0, 0, 0, 0, 0]]