百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 文章教程 > 正文

七夕前学起来,程序员的浪漫:三十行代码实现用她的名字作幅画

yund56 2025-05-14 18:25 13 浏览

hello,各位小伙伴们大家早上|中文|晚上|凌晨好,相信看这篇文章的有很多新朋友,估计也有少量的老朋友,首先做个简短的自我介绍,我是一灰灰,码农界的资深搬运工;今天呢,没有站在我身边的捧哏老师,那就只好给大伙来个单口的灌水博文了

大街上铺天盖地的520促销优惠买一赠一的宣传语,宣告了初夏的第一个特殊节日,可好巧不巧的是到了5.21号这天我才发现,居然又到了520啊,然后再一看手机,卧槽,居然过了。。。这特么回家还不得跪我那斥巨资200大洋买的机械键盘了

赶紧发动一下高达249IQ的大脑,思考一下有什么补救的措施,是时候解开封印已旧的人肉爬虫技能,看看票圈晒图的朋友们,能不能提供有价值的灵光一现

功夫终负有心人,果不其然毫无收获;老老实实的发挥一下职业特长,码农可以整些什么浪漫的活 呢?

  • 写个html页面,陪她去看流星雨
  • 用她的照片组个带音乐、能自动播放的PPT
  • 黑个商场大屏幕,附上她的美图秀秀 + 爱你一万年
  • AI自动写个xxx 爱你一万年的藏头诗
  • 写个无界面的APP,偷偷装在她的手机上,设置定时弹出一朵鲜花(不怕被打的话恐怖图片也可以)

可选择的不少,接下来就剩下一个小问题了,5.21号送出5.20号的小礼物能被原谅么?(请看到这里的美少女么摸着自己的良心,在评论区大声告诉我”能“ 好么)

话接上文,就算有再多得小仙女告诉我能,讲道理我也不敢信啊,接下来免费给各位看官分享一个价值99¥的idea,用她的名字做一幅画(如下),然后深情的告诉她,全是手绘,这么大的工作量,delay个一两天不很正常么(请大声告诉我,是不是很机智)

接下来,老司机教你如何使用三十行用她(他它)的名字画出她的艺术画

写了这么多居然还没有进入主题,这文章灌水得我自己都有点看不过去了,言归正传,接下来我们看下,如何实现用她的名字来作画呢?

1. 作战思路

目标有了,接下来就是定方案了,大家都知道计算机的世界是由0和1组成,那么图片的世界又是由什么组成呢?

我已经听到聪明机智的小伙伴内心的答案了,对,没错,就是一个一个带有颜色的像素块

那么我们要做的是什么呢?答案已经呼之欲出了,各位少侠小仙女么,请大声告诉我好么

咳咳,说正经的,就是将将这一个一个像素块,然后用她(他它)的名字替换就行了

2. 战前准备

俗话说兵马未动,粮草先行,正式开干之前,先做一些必要的准备

  • 一张美丽动人的图片 先将背景处理一下,保留关键的人物信息,减少噪音 不会ps的小伙伴,可以直接使用 www.remove.bg/zh 三秒完成抠图

如有侵权,联系即删,只要不赔钱,要啥都行

  • 选择开动的技术栈 java, php, golang, js, python?

既然如此,那我们遵循自愿原则,就决定是你了 -- 爪蛙(JAVA)

3. 开战

感谢各位小伙伴选择java 我的本命技能,那我们来看一下如何来实现我们的目的, 正如把大象塞入冰箱只需要三步一样,需要实现的步骤也很简单

步骤拆解:

  • 读取图片
  • 并创建一个等大的画板
  • 遍历图片的每个像素点,读取像素点的RGB
  • 在画板对应的位置上渲染文字
  • 保存画板,大功告成

实现源码:

public static Color int2color(int color) {
    int a = (0xff000000 & color) >>> 24;
    int r = (0x00ff0000 & color) >> 16;
    int g = (0x0000ff00 & color) >> 8;
    int b = (0x000000ff & color);
    return new Color(r, g, b, a);
}

public void renderCharPhoto(String imgPath, String name, String saveFile) throws Exception {
	// 第一步,载图片
    BufferedImage img = ImageIO.read(new File(imgPath));
    int w = img.getWidth(), h = img.getHeight();

	// 第二步,创建等大的画板
    BufferedImage output = new BufferedImage(w, h, img.getType());
    Graphics2D g2d = output.createGraphics();
    g2d.setFont(new Font("宋体", Font.PLAIN, 1));
    int index = 0;
    for (int x = 0; x < w; x++) {
        for (int y = 0; y < h; y++) {
        	// 第三步,遍历每个像素点,并获取对应的rgb
            char ch = name.charAt((index++) % name.length());
            g2d.setColor(int2color(img.getRGB(x, y)));
            // 第四步,写上他她它的名字
            g2d.drawString(String.valueOf(ch), x, y);
        }
    }

	// 第五步,保存图片
    g2d.dispose();
    ImageIO.write(output, "png", new File(saveFile));
}
复制代码

就这么简单,赶紧跑一下试试效果

好像有什么地方不对劲,这和原图没啥两样啊,那么问题出在哪呢?一个像素点上的文字,我的钛合金四眼看不见啊,那可以怎么办呢?

有道理,把图片放大,不就ok了么,那么将上面的画板调整一下,放大24倍,设置字体大小20,给字与字之间留点空隙

public void renderCharPhoto(String imgPath, String name, String saveFile) throws Exception {
    BufferedImage img = ImageIO.read(new File(imgPath));
    int w = img.getWidth(), h = img.getHeight();

    BufferedImage output = new BufferedImage(w * 24, h * 24, img.getType());
    Graphics2D g2d = output.createGraphics();
    g2d.setFont(new Font("宋体", Font.PLAIN, 20));
    int index = 0;
    for (int x = 0; x < w; x++) {
        for (int y = 0; y < h; y++) {
            char ch = name.charAt((index++) % name.length());
            g2d.setColor(int2color(img.getRGB(x, y)));
            g2d.drawString(String.valueOf(ch), x * 24 + 2, y * 24 + 2);
        }
    }

    g2d.dispose();
    ImageIO.write(output, "png", new File(saveFile));
}
复制代码

原图看右边,放大不失真: blog.hhui.top/hexblog/img…

这标准的宋体好像暴露了什么,要是告诉他(她它)这是手绘的,能信么?

为了更逼真一点,换个手绘字体试一试,网上搜索一下,从这里
www.diyiziti.com/Builder/446 下载了一个 潇洒手写体资源

然后再调整一下上面代码中的字体设置

public void renderCharPhoto(String imgPath, String name, String saveFile) throws Exception {
    BufferedImage img = ImageIO.read(new File(imgPath));
    int w = img.getWidth(), h = img.getHeight();

    BufferedImage output = new BufferedImage(w * 24, h * 24, img.getType());
    Graphics2D g2d = output.createGraphics();

	// 使用自定义的字体
    try (InputStream inputStream = Files.newInputStream(Paths.get("D://MobileFile/潇洒手写体.ttf"))) {
        Font font = Font.createFont(Font.TRUETYPE_FONT, inputStream);
        g2d.setFont(font.deriveFont(Font.PLAIN, 20));
    }
    int index = 0;
    for (int x = 0; x < w; x++) {
        for (int y = 0; y < h; y++) {
            char ch = name.charAt((index++) % name.length());
            g2d.setColor(int2color(img.getRGB(x, y)));
            g2d.drawString(String.valueOf(ch), x * 24 + 2, y * 24 + 2);
        }
    }

    g2d.dispose();
    ImageIO.write(output, "png", new File(saveFile));
}
复制代码

原图看右边,放大不失真: blog.hhui.top/hexblog/img…

如果对方很熟悉你的字体怎么办?

解决办法也有,应用商店搜索一下"造字",还可以顺便给自己打造一个独一无二的字体

棒,这下感觉无懈可击了啊,只要把上面的图片找个打印店,彩绘一下,完事了啊;拿走,不谢

如果不幸的是,当你有个机智的对象时,那么她/他/它多半会给你灵魂一问,你是如何做到,字和间距都分毫不差的?

最后叨叨了这么久,忽然想到一个问题,520这个节日,和我这没有女票的人有什么关系么?

4. 战后福利

上面三十行代码手把手教你实现了一个(糊弄)女票的方法,基本功能还是很完整的,当然如此贴心的一灰灰我,也给各位小伙伴提供了更友好的方式,如直接从网上加载图片、字体

public void testCharPicture() throws Exception {
    prefix = "/tmp/";
    String img = "http://hbimg.b0.upaiyun.com/2b79e7e15883d8f8bbae0b1d1efd6cf2c0c1ed1b10753-cusHEA_fw236";
    ImgPixelWrapper.build()
            .setSourceImg(img)
            .setChars("小黄人")
            // 字体文件下载地址: https://www.diyiziti.com/Builder/446
            .setFontName("https://font.js.live/front/font/download?id=446")
            .setBlockSize(24)
            .setFontSize(22)
            .setBgPredicate(color -> {
                // 指定背景色,不渲染文本
                if (color == 0)  return true;
                Color rc = ColorUtil.int2color(color);
                // 将白色当作背景色
                return rc.getRed() >= 245 && rc.getGreen() >= 245 && rc.getBlue() >= 245;
            })
            .setPixelType(PixelStyleEnum.CHAR_SEQ_SCALE_UP)
            .build().asFile(prefix + "/char_pic_xhr.jpg");
    System.out.println("---- over ---");
}
复制代码

对应的源码: github.com/liuyueyi/qu…

引入方式也很简单

<artifactId>image-plugin</artifactId>
<groupId>com.github.liuyueyi.media</groupId>
<version>2.6.4</version>
复制代码

是不是很贴心,是不是很感动,是不是应该点个赞、给个评论支持,加个收藏下次备用呢


作者:一灰灰
链接:
https://juejin.cn/post/7100429445525143583


相关推荐

今日起,办理游戏版号这么做就行了!真的太方便了

  在“大众创业,万众创新”的浪潮下,我国很多创业者也看到了游戏的前景,准备在游戏行业分一杯羹。  但根据国家新闻出版广电总局颁布的《关于移动游戏出版服务管理的通知》,游戏需要通过国家新闻出版广电总局...

给大家推荐些好的c语言代码的网站

C语言,那就来推荐几个吧,部分含有C++:1、TheLinuxKernelArchives(kernel.org)Linux内核源码,仅限于C,但内核庞大,不太适合新手;2、redis(redi...

手游平台没有源码的三大危害

搭建一款属于自己的手游平台可以直接和游戏研发商对接游戏,既减少中介的差价,还能根据自己需求去选择游戏。对于玩家而言,手游平台给予了玩家更多的选择机会,对于运营者而言,借助平台可以更好地服务玩家,通过对...

游戏源代码开发时需要什么,需要哪些团队成员?

游戏由于她轻松娱乐,对战刺激,寓教于乐等特点,吸引住了一大批不一样年龄阶段的用户,例如喜爱竞技游戏的年轻群体,需要益智游戏的儿童等。游戏源代码是游戏构建的基础,尽管将开发时分成开发软件和游戏开发2个概...

育碧经典游戏《孤岛惊魂1》源代码遭泄露,玩家表示可以运行

IT之家7月3日消息,一份名为“FarCry1.34Complete”的游戏源代码已经出现在了互联网档案网站“Archive.org”上,并且在Reddit论坛和各种社交媒体上得到...

神秘网站倒数结束 令人一头雾水

还记得那个疑似小岛秀夫作品的《黑色猎犬》倒计时网站吗?现在该网站已经停止倒计时,仅剩一段话“这里原来有一个倒计时,现在没了”……点击这句话会跳转到国外网站Funhaus的一个莫名其妙的视频,然而评论的...

LOL源代码娜美免费领取地址 LOL源代码娜美领取活动网址分享

[海峡网]在英雄联盟中近日国服的服务器一直不稳定,繁出现卡顿和功能错误等问题,官方现在正在努力维护,为表歉意将免费赠送给玩家一款“源代码·娜美”的皮肤,那么这个皮肤要怎么领取呢,小编相信小伙伴们一定都...

个人网站集成js小游戏《圈小猫》教程及源码

今天在某网站浏览帖子的时候,发现帖子被删除了,然后弹出了404页面,页面上集成了一个小游戏,小游戏长什么样子呢?看下面这个图!第一步查看小游戏源码,发现这个小游戏完全是由JavaScript编写的,因...

Scratch创意编程-数学问答游戏

项目名称:数学问答游戏目标年龄群体:8-12岁项目简介:在这个Scratch创意编程项目中,学生们将扮演数学家,通过解答数学题目来挑战自己的数学技能。游戏中包含了加法、减法、乘法和除法等基本算术题,以...

少时不努力长大程序猿 酷比魔方AI百变编程套件体验测评

本文产品为厂家送测,坚持独立的评价观点是笔者创作的基本底线,绝不会因商品来源不同而有所偏颇,请各位放心。写在开始讲讲今天男主的故事这篇体验到的目标群体是跟我一样,家中有个在上小学二年级的小学生。首先...

孩子的scratch作品只能演示?教你把它三步变为电脑软件

随着少儿编程的发展,越来越多的家长和孩子开始投身其中。对于初学者来说,最好的编程工具就是Scratch,它是麻省理工学院的“终身幼儿园团队”开发的图形化编程工具,主要面对青少年开放。这是对孩子最好的编...

打地鼠小游戏制作教程

打地鼠这个小游戏貌似比我的年龄都要大,这次我们使用scratch3.0图形化编程软件来制作一款我们自己的“打地鼠”。我们先准备4样角色,分别是:地鼠角色、锤子角色、地洞角色、草地角色。地鼠→使用猫...

Scratch2.0接苹果小游戏讲义整理

Scratch2.0接苹果小游戏概貌见动图:这又是一款经典的Scratch小游戏,是孩子们学习Scratch编程软件的良好载体,不容错过。(一)玩法说明接到慢速的红苹果一个加1分;接到中速的红苹果一个...

少儿编程太难?原来可以闯关玩游戏啊

随着编程学习全球化的趋势,国内编程学习热潮日盛,越来越多的家长开始让孩子接触学习编程。然而我们都不了解这个少儿编程是到底是什么,近年来,许多家长开始给小孩报编程学习班。最小的从幼儿园开始就在学习...

如何在Scratch中创建一个两人赛艇游戏

本分步指南将教您如何使用Scratch程序创建划船游戏。完成对这个简单游戏的编程后,两条船将使用按键命令一起竞赛。步骤1.打开Scratch。2.删除名为“Sprite1”的猫。您可以通过右键单击它...