python 制作3d立体隐藏图

生成文件的3d图,例子:

文字:

隐藏图:

使用建议:

1、建议不用中文,因为中文太复杂,生成立体图效果不好。

2、需要指定FONT_PATH,为一个ttf文件,linux在/usr/share/fonts目录下,windows在C:\Windows\Fonts

3、建议字体TEXT_SIZE调大,不然不好分辨

4、指定的TEXT不要太长

5、多试几次,找到合适的纹理

python 复制代码
from PIL import Image, ImageDraw, ImageFont
from random import *
import numpy as np
from io import BytesIO


FONT_PATH = '/usr/share/fonts/dejavu/DejaVuSans.ttf'   # 字体位置,linux在/usr/share/fonts/,windows
TEXT = 'love yannis'
TEXT_SIZE = 100 # 字体大小
WIDTH = 100 + int(len(TEXT) * TEXT_SIZE / 1.8)
HEIGHT = 256
SHIFT = 4 # 叠加位移

# 生成纹理
def clamp(n, smallest, largest):
    return max(smallest, min(n, largest))

def rand_ratio(base=1, delta=1):
    return delta * randint(1,100)*1.0/100 + base

rand_ratios = [rand_ratio(), rand_ratio(), rand_ratio()]

color_starts = [randint(0,200), randint(0,200), randint(0,200)]

def rand_color(i):
    return clamp(randint(color_starts[i],int(rand_ratios[i] * color_starts[i])), 0, 255) 

def rand_colors():
    return (rand_color(0),rand_color(1),rand_color(2))

perodic_x = 40
perodic_y = 40
texture = np.zeros((perodic_x, perodic_y, 3))
same_to_last_x = [False] * perodic_x
same_to_last_y = [False] * perodic_y
for x in range(0, perodic_x):
    same_to_last_x[x] =  random() < 0.1
for y in range(0, perodic_y):
    same_to_last_y[y] =  random() < 0.3

texture[0][0] = rand_colors()

for x in range(0,perodic_x):
    if same_to_last_x[x]:
        texture[x][0] = texture[x-1][0]
    else:
        texture[x][0] = rand_colors()

# 纹理平铺
for x in range(0, perodic_x):
    for y in range(0,perodic_y):
        if same_to_last_y[y]:
            texture[x][y] = texture[x][y-1]
        elif same_to_last_x[x]:
            texture[x][y] = texture[x-1][y]
        else:
            texture[x][y] = rand_colors()

# 生成纹理平铺图片
img = Image.new('RGB', (WIDTH, HEIGHT), color = 'white')
img_draw = ImageDraw.Draw(img) 
for x in range(0, WIDTH):
    for y in range(0,HEIGHT):
        color = texture[x % perodic_x][y % perodic_y].astype(int).tolist()
        img_draw.point([x,y], fill = tuple(color))


# 生成文字
text = Image.new('RGB', (WIDTH, HEIGHT), color = 'black')
text_draw = ImageDraw.Draw(text) 
font = ImageFont.truetype(FONT_PATH, size=TEXT_SIZE)
text_draw.text((50,(HEIGHT-TEXT_SIZE)/2), TEXT, font=font, fill='white')

# 文字叠加
img_mat = np.asarray(img)
text_mat = np.asarray(text)

for x in range(0, WIDTH - SHIFT):
    for y in range(0, HEIGHT):
        if text_mat[y][x][0] != 0:
            img_draw.point([x,y], fill = tuple(img_mat[y, x - SHIFT].tolist()))
text.save('../tmp2.png', 'png')
img.save('../tmp.png', 'png')
相关推荐
少云清2 分钟前
【金融项目实战】7_接口测试 _代码实现接口测试(重点)
python·金融项目实战
深蓝电商API3 分钟前
爬虫IP封禁后的自动切换与检测机制
爬虫·python
R1nG8634 分钟前
多线程安全设计 CANN Runtime关键数据结构的锁优化
开发语言·cann
m0_550024635 分钟前
持续集成/持续部署(CI/CD) for Python
jvm·数据库·python
初次见面我叫泰隆5 分钟前
Qt——5、Qt系统相关
开发语言·qt·客户端开发
亓才孓10 分钟前
[Class的应用]获取类的信息
java·开发语言
哈__13 分钟前
CANN加速3D目标检测推理:点云处理与特征金字塔优化
目标检测·3d·目标跟踪
开开心心就好18 分钟前
AI人声伴奏分离工具,离线提取伴奏K歌用
java·linux·开发语言·网络·人工智能·电脑·blender
Never_Satisfied22 分钟前
在JavaScript / HTML中,关于querySelectorAll方法
开发语言·javascript·html
B站_计算机毕业设计之家36 分钟前
豆瓣电影数据采集分析推荐系统 | Python Vue Flask框架 LSTM Echarts多技术融合开发 毕业设计源码 计算机
vue.js·python·机器学习·flask·echarts·lstm·推荐算法