import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.GraphicsEnvironment;
import java.awt.geom.Rectangle2D;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Scanner;

public class CharWrittenInChar {
	public static void main(String[] args) {
		new CharWrittenInChar();
	}

	Scanner cin = new Scanner(System.in);
	char foreChar = '●', backChar = '○', writing = '福';
	BufferedImage pic;
	Font[] font;
	int from, to, cur;// 字体从哪里开始到哪里结束
	int width = 40, height;

	BufferedImage getPic() {
		Font f = new Font(font[cur].getName(), Font.BOLD, 150);
		BufferedImage bit = new BufferedImage(1000, 1000, BufferedImage.TYPE_3BYTE_BGR);
		Rectangle2D rec = bit.getGraphics().getFontMetrics(f).getStringBounds("" + writing, bit.getGraphics());
		bit = new BufferedImage((int) rec.getWidth() + 1, 1 + (int) rec.getHeight(), BufferedImage.TYPE_3BYTE_BGR);
		Graphics gg = bit.getGraphics();
		gg.setColor(Color.black);
		gg.fillRect(0, 0, bit.getWidth(), bit.getHeight());
		gg.setFont(f);
		gg.setColor(Color.RED);
		gg.drawString("" + writing, 0, gg.getFontMetrics(f).getAscent());
		return bit;
	}

	void draw(BufferedImage bit, FileOutputStream file) throws IOException {
		height = bit.getHeight() * width / bit.getWidth();
		BufferedImage pic = new BufferedImage(width, height, BufferedImage.TYPE_3BYTE_BGR);
		pic.getGraphics().drawImage(bit, 0, 0, width, height, null);
		String s = "\n\n\n" + font[cur].getName() + "------------\r\n\r\n";
		for (int j = 0; j < pic.getHeight(); j++) {
			for (int i = 0; i < pic.getWidth(); i++) {
				int k = pic.getRGB(i, j);
				if (k == -65536) {
					s += foreChar;
				} else {
					s += backChar;
				}
			}
			s += "\r\n";
		}
		cout(s);
		file.write(s.getBytes());
	}

	void output() {
		try {
			FileOutputStream file = new FileOutputStream(new File("result.txt"));
			for (cur = from; cur < to; cur++) {
				pic = getPic();
				draw(pic, file);
			}
			file.close();
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	CharWrittenInChar() {
		GraphicsEnvironment e = GraphicsEnvironment.getLocalGraphicsEnvironment();
		font = e.getAllFonts();
		from = 0;
		to = 8;
		cur = 0;
		pic = getPic();
		output();
		run();
	}

	void run() {
		while (true) {
			cout("weidiao >");
			Scanner str = new Scanner(cin.nextLine());
			if (!str.hasNext()) {
				output();
				continue;
			}
			String cmd = str.next();
			if (cmd.equals("help")) {
				cout("Character Generater---made by weidiao.neu\n");
				cout("\t\tfore 前景字\n");
				cout("\t\tback 背景字\n");
				cout("\t\twriting 正在写\n");
				cout("\t\twidth 宽度\n");
				cout("\t\treset 重置全部字符及大小\n\n");
			} else if (cmd.equals("reset")) {
				foreChar = '●';
				backChar = '○';
				writing = '福';
				width = 40;
				output();
			} else {
				if (str.hasNext()) {
					switch (cmd) {
					case "fore":
						foreChar = str.next().charAt(0);
						output();
						break;
					case "back":
						backChar = str.next().charAt(0);
						output();
						break;
					case "writing":
						writing = str.next().charAt(0);
						output();
						break;
					case "width":
						width = new Integer(str.next());
						output();
						break;
					default:
						cout("illegal command\n");
					}
				} else {
					cout("illegal command\n");
				}
			}
			str.close();
		}
	}

	void cout(String s) {
		System.out.print(s);
	}
}

本程序用来"用字符写字符".给定一个字符,用很多个字符把这个字符拼起来.

原理是,把字符画在图片上(用Graphics.drawString函数),然后把这张图片画在一个固定大小的图片上.

现在,图片上只有两种颜色:前景色和背景色.

这就相当于一个二维矩阵,矩阵中有两种字符:前景字符和背景字符.

有三个东西可以进行设置:前景字符,背景字符,正在写的字符

java用字符写字符的更多相关文章

  1. java IO流 之 字符流

    字符是我们能读懂的一些文字和符号,但在计算机中存储的却是我们看不懂的byte 字节,那这就存在关于字符编码解码的问题.所以在学习Io流的字符流前我们先了解些关于编码问题. 一.字符集与字符编码 1.什 ...

  2. Java:IO流之字符流Reader、Writer详解

    java.io包中:字符流   字符流的两个抽象基类:   Reader         Writer   文件的读取:Reader抽象类(java.io包中) 直接子类的构造方法: FileRead ...

  3. java中字节流和字符流的区别

    流分类: 1.Java的字节流   InputStream是所有字节输入流的祖先,而OutputStream是所有字节输出流的祖先.2.Java的字符流  Reader是所有读取字符串输入流的祖先,而 ...

  4. java把html标签字符转普通字符(反转换成html标签)(摘抄)

    下面是java把html标签字符转换,我用了spring 包中的 org.springframework.web.util.HtmlUtils 了解了源代码并且进步了使用,发现写得真不错...同时也可 ...

  5. 【Java基础】【21IO(字符流)&字符流其他内容&递归】

    21.01_IO流(字符流FileReader) 1.字符流是什么 字符流是可以直接读写字符的IO流 字符流读取字符, 就要先读取到字节数据, 然后转为字符. 如果要写出字符, 需要把字符转为字节再写 ...

  6. JAVA是是如何处理字符的。

    String s = "fs123fdsa";//String变量 byte b[] = s.getBytes();//String转换为byte[] String t = new ...

  7. 缓冲字符流 java.io.BufferedWriter ,java.io.BufferedReader,缓冲字符输出流:PrintWriter

    package seday07; import java.io.IOException;import java.io.PrintWriter; /*** @author xingsir * 缓冲字符流 ...

  8. Java IO---字节流和字符流

    一.IO流简介 流 流是一个抽象概念,Java程序和外部设备(可以是硬盘上的文件,也可以是网络设备)之间的输入输出操作是基于流的. 流就好比水管中的水流,具有流入和流出,类比数据的输入和输出. Jav ...

  9. Java IO: 字节和字符数组

    原文链接  作者: Jakob Jenkov   译者:homesick 内容列表 从InputStream或者Reader中读入数组 从OutputStream或者Writer中写数组 在java中 ...

随机推荐

  1. Android gdb 调试

    [1].终端目录设置到: proj.android[2].make文件的编译选项加上: -g -gstabs+[3].执行编译脚本: sh ./build_native.sh NDK_DEBUG=1[ ...

  2. Hadoop多硬盘配置时的注意事项

    <!-- hdfs-site.xml --> <property> <name>dfs.datanode.fsdataset.volume.choosing.pol ...

  3. 理解 OpenStack + Ceph (5):OpenStack 与 Ceph 之间的集成 [OpenStack Integration with Ceph]

    理解 OpenStack + Ceph 系列文章: (1)安装和部署 (2)Ceph RBD 接口和工具 (3)Ceph 物理和逻辑结构 (4)Ceph 的基础数据结构 (5)Ceph 与 OpenS ...

  4. 学习OpenStack之 (4): Linux 磁盘、分区、挂载、逻辑卷管理 (Logical Volume Manager)

    0. 背景: inux用户安装Linux操作系统时遇到的一个常见的难以决定的问题就是如何正确地评估各分区大小,以分配合适的硬盘空间.普通的磁盘分区管理方式在逻辑分区划分好之后就无法改变其大小,当一个逻 ...

  5. 学习OpenStack之 (0):基础知识

    vi 方向键出现字母问题解决方法 执行命令 sudo apt-get remove vim-common 执行命令 sudo apt-get install vim 鼠标被virtualbox捕获无法 ...

  6. HDU 5895 Mathematician QSC(矩阵乘法+循环节降幂+除法取模小技巧+快速幂)

    传送门:HDU 5895 Mathematician QSC 这是一篇很好的题解,我想讲的他基本都讲了http://blog.csdn.net/queuelovestack/article/detai ...

  7. 使用ztree.js,受益一生,十分钟学会使用tree树形结构插件

    看到ztree.js,这几个字眼,毋庸置疑,那肯定就是tree树形结构了,曾经的swing年代有jtree,后来jquery年代有jstree和treeview,虽然我没写过,但是我见过,一些小功能做 ...

  8. 嵌入式Linux驱动学习之路(八)创建最小的根文件系统

    busybox 在配置busybox,在是否选择要静态链接库时,在静态下,busybox中的工具不需要动态链接库,能够直接运行.而用户自己编写的程序如果需要动态链接库,还是依然需要有. 如果是动态链接 ...

  9. 嵌入式Linux 修改启动LOGO

    1.嵌入式 Linux LOGO显示原理      嵌入式Linux是直接在FrameBuffer的基础上.直接显示一个ppm格式的图象.     它 kernel/drivers/video/fbc ...

  10. Nginx反向代理和负载均衡——个人配置

    #user nobody; worker_processes 2; #error_log logs/error.log; #error_log logs/error.log notice; #erro ...