服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - java 生成文字图片的示例代码

java 生成文字图片的示例代码

2020-12-19 13:53LzwGlory Java教程

本篇文章主要介绍了java 生成文字图片的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

本文主要介绍了java 生成文字图片的示例代码,分享给大家,具体如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
import java.awt.Color;
import java.awt.Font;
import java.awt.FontMetrics;
import java.awt.Graphics;
import java.awt.Rectangle;
import java.awt.image.BufferedImage;
import java.io.File;
 
import javax.imageio.ImageIO;
 
public class FontImage {
  public static void main(String[] args) throws Exception {
    createImage("请A1003到3号窗口", new Font("宋体", Font.BOLD, 30), new File(
        "e:/a.png"), 4096, 64);
    createImage("请A1002到2号窗口", new Font("黑体", Font.BOLD, 35), new File(
        "e:/a1.png"), 4096, 64);
    createImage("请A1001到1号窗口", new Font("黑体", Font.PLAIN, 40), new File(
        "e:/a2.png"), 4096, 64);
  }
 
  // 根据str,font的样式以及输出文件目录
  public static void createImage(String str, Font font, File outFile,
      Integer width, Integer height) throws Exception {
    // 创建图片
    BufferedImage image = new BufferedImage(width, height,
        BufferedImage.TYPE_INT_BGR);
    Graphics g = image.getGraphics();
    g.setClip(0, 0, width, height);
    g.setColor(Color.black);
    g.fillRect(0, 0, width, height);// 先用黑色填充整张图片,也就是背景
    g.setColor(Color.red);// 在换成黑色
    g.setFont(font);// 设置画笔字体
    /** 用于获得垂直居中y */
    Rectangle clip = g.getClipBounds();
    FontMetrics fm = g.getFontMetrics(font);
    int ascent = fm.getAscent();
    int descent = fm.getDescent();
    int y = (clip.height - (ascent + descent)) / 2 + ascent;
    for (int i = 0; i < 6; i++) {// 256 340 0 680
      g.drawString(str, i * 680, y);// 画出字符串
    }
    g.dispose();
    ImageIO.write(image, "png", outFile);// 输出png图片
  }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:http://blog.csdn.net/lzwglory/article/details/48056169

延伸 · 阅读

精彩推荐