Java图形程序中的对话逐字显示实现

简介:
在现代,摒弃传统的会话方式,很多的图形广告或游戏采用了[逐字打印]的效果来展示文字,当然,这样做的目的无非是为了突出内容或吸引眼球。

但是这种实现方式却是值得借鉴的,以下,我给出一个JAVA实现的简单用例,需要者可以自行扩充。

代码实现:

package  org.test;

import  java.awt.Color;
import  java.awt.Font;
import  java.awt.Frame;
import  java.awt.Graphics;
import  java.awt.Image;
import  java.awt.Panel;
import  java.awt.image.BufferedImage;

import  org.loon.framework.game.helper.ImageHelper;

/**
 * <p>
 * Title: LoonFramework
 * </p>
 * <p>
 * Description:JAVA实现对话逐字打印(由Loonframework提供)
 * </p>
 * <p>
 * Copyright: Copyright (c) 2007
 * </p>
 * <p>
 * Company: LoonFramework
 * </p>
 * 
 * 
@author chenpeng
 * @email:[email]ceponline@yahoo.com.cn[/email]
 * 
@version 0.1
 
*/


public   final   class  WriterType  extends  Panel  implements  Runnable  {
    
// 最大对话数
    private int _MAX_COUNT = 10;

    
//间隔标记
    private char _flag='|';
    
    
private Image _screen;

    
private Graphics _bg;

    
private Thread _L_WriterType;

    
private static Color _L_fClr;

    
private static Color _L_bClr;

    
private static String _M_Text[];

    
private int _S_COUNT;

    
private Font _L_TTF;

    
private int _L_Speed;

    
private int _L_Delay;

    
private String _C_Text[];

    
private static int _L_COUNT;

    
private static int _F_COUNT;
    
    
private static int _T_COUNT;

    
private static int _N_Text;

    
private String _FontName;

    
private final static int _WIDTH = 500;

    
private final static int _HEIGHT = 375;

    
private static int _FontStyle;

    
private static int _FontSize;

    
private static  Image _back = null;

    
/**
     * 
     
*/

    
private static final long serialVersionUID = 1L;

    
private boolean _isRun;

    
/**
     * 析构函数,注入背景图,循环显示的文字数组,速度,延迟
     * 
@param img
     * 
@param strContent
     * 
@param speed
     * 
@param delay
     
*/

    
public WriterType(Image img,String[] strContent, int speed, int delay) {
        init(img,strContent, speed, delay);
    }


    
private WriterType() {

    }


    
public void init(Image img,String[] strContent, int speed, int delay) {
        
//初始背景色
        setBackground(Color.BLACK);
        
// 原始对话信息
        _M_Text = new String[_MAX_COUNT];
        
// 缓存对话信息
        _C_Text = new String[_MAX_COUNT];

        _back
=img;
        _FontName 
= "宋体";

        _FontStyle 
= 0;

        _FontSize 
= 15;

        _L_TTF 
= new Font(_FontName, _FontStyle, _FontSize);
        _L_bClr 
= Color.BLACK;
        _L_fClr 
= new Color(250250250);

        
int length = strContent.length;

        
// 循环次数
        _N_Text = strContent.length - 1;

        
// 直接copy String数组
        System.arraycopy(strContent, 0, _M_Text, 0, length);

        
//速度及延迟设定
        _L_Speed = speed;
        _L_Delay 
= delay;
        
        
//缓存区域
        _screen = new BufferedImage(_WIDTH, _HEIGHT, 1);
        _bg 
= _screen.getGraphics();

        
//开启线程
            _isRun = true;
            _L_WriterType 
= new Thread(this);
            _L_WriterType.start();
        
    }


    
/**
     * 停止线程
     *
     
*/

    
public void stop() {
        _S_COUNT 
= 0;
        _L_COUNT 
= 0;
        _F_COUNT 
= 0;
        
if (_L_WriterType != null{
            _isRun 
= false;
            _L_WriterType 
= null;
        }

    }


    
/**
     * 绘制图形
     
*/

    
public void paint(Graphics g) {
        _bg.setColor(_L_bClr);
        _bg.fillRect(
00, _WIDTH, _HEIGHT);
        _bg.setColor(_L_fClr);
        _bg.setFont(_L_TTF);
        _bg.drawImage(_back, 
00this);
        
for (int i = 0; i <= _L_COUNT; i++{
            
//转换当前字体top位置
            Double top = new Double((double) _FontSize
                    
* (3.0D + 2.0D * (double) i));
            
if (_C_Text[i] != null{
                _bg.drawString(_C_Text[i], 
50, top.intValue());
            }

        }


        g.drawImage(_screen, 
00this);
    }


    
/**
     * 图形变更
     
*/

    
public void update(Graphics g) {
        paint(g);
    }


    
/**
     * 重新开始
     *
     
*/

    
private void begin() {
        
//清除所有缓存数据。
        for (int i = 0; i < _C_Text.length; i++{
            _C_Text[i] 
= null;
        }

        _F_COUNT 
= 0;
        _S_COUNT 
= 0;
        _L_COUNT 
= 0;
        _T_COUNT
++;
        
if (_T_COUNT > _N_Text) {
            _T_COUNT 
= 0;
        }

        repaint();
    }


    
public void run() {
        
while (_isRun) {
            
try {

                
//字符串累加
                _S_COUNT++;
                
//当字符串完成整段对话时
                if (_S_COUNT == _M_Text[_T_COUNT].length()) {
                    _C_Text[_L_COUNT] 
= _M_Text[_T_COUNT].substring(_F_COUNT,
                            _S_COUNT);
                    begin();
                    Thread.sleep(_L_Delay);
                    repaint();
                }

                
//比对标识设定缓存对话
                if (_M_Text[_T_COUNT].charAt(_S_COUNT) != _flag) {
                    _C_Text[_L_COUNT] 
= _M_Text[_T_COUNT].substring(_F_COUNT,
                            _S_COUNT)
                            
+ "_";
                }
 else {
                    _C_Text[_L_COUNT] 
= _M_Text[_T_COUNT].substring(_F_COUNT,
                            _S_COUNT);
                }

                
//用以分辨是否转化对话组时的不同延迟
                boolean shortSleep;
                
//当'|'标识存在时执行
                if (_M_Text[_T_COUNT].charAt(_S_COUNT) == _flag) {
                    _L_COUNT
++;
                    _S_COUNT
++;
                    _F_COUNT 
= _S_COUNT;
                    shortSleep 
= true;
                }
 else {
                    shortSleep 
= false;
                }

                
//刷新
                repaint();
                
//判断速度
                if (!shortSleep) {
                    Thread.sleep(_L_Speed);
                }
 else {
                    Thread.sleep(
10 * _L_Speed);
                }

            }
 catch (InterruptedException e) {
                stop();
            }

        }

    }

    
    
public int getMaxCount() {
        
return _MAX_COUNT;
    }


    
public void setMaxCount(int max_count) {
        _MAX_COUNT 
= max_count;
    }


    
public static void main(String[] args) {
        String[] abracadabra 
= new String[] {
                
"身为剑体,|钢铁之血灼璃之心.|手创千剑,身经百战;|无一败绩,无一知己.|常一人自醉于剑丘之巅;|此生亦无任何意义;|故此身,定为无限剑成;|故此命,定为无限剑制.",
                
"I am the bone of my sword;|Steel is my body, and fire is my blood.|I have created over a thousand blades.|Have withstood pain to create many weapons.|Yet,those hands will never hold anything.|So as I pray, unlimited blade works." }
;
        Frame frm 
= new Frame();
        frm.setTitle(
"Java图形程序中的对话逐字显示(由Loonframework提供)");
        frm.setSize(_WIDTH, _HEIGHT 
+ 20);
        frm.setResizable(
false);
        frm.add(
new WriterType(ImageHelper
                .loadImage(
"d:/back.jpg"true),abracadabra,50,5000));
        frm.setVisible(
true);
    }




}


本例自动循环String数组中所有数据,每行显示对话由'|'标记分割,背景图如下:



效果图1如下:


效果图2如下:



本文转自 cping 51CTO博客,原文链接:http://blog.51cto.com/cping1982/130198

相关文章
|
18天前
|
缓存 监控 安全
如何提高 Java 高并发程序的性能?
以下是提升Java高并发程序性能的方法:优化线程池设置,减少锁竞争,使用读写锁和无锁数据结构。利用缓存减少重复计算和数据库查询,并优化数据库操作,采用连接池和分库分表策略。应用异步处理,选择合适的数据结构如`ConcurrentHashMap`。复用对象和资源,使用工具监控性能并定期审查代码,遵循良好编程规范。
|
30天前
|
Java 编译器 开发者
Java中的异常处理是确保程序稳定性的关键
Java中的异常处理是确保程序稳定性的关键。本文探讨八大最佳实践:理解异常体系,选用恰当异常类型,提供详细错误信息,精用try-catch,善用finally块,利用try-with-resources简化资源管理,记录异常便于追踪,及避免finally中抛异常。遵循这些原则,提升代码质量和错误管理能力。
14 1
|
1月前
|
Java 开发者
在Java编程的广阔天地中,if-else与switch语句犹如两位老练的舵手,引领着代码的流向,决定着程序的走向。
在Java编程中,if-else与switch语句是条件判断的两大利器。本文通过丰富的示例,深入浅出地解析两者的特点与应用场景。if-else适用于逻辑复杂的判断,而switch则在处理固定选项或多分支选择时更为高效。从逻辑复杂度、可读性到性能考量,我们将帮助你掌握何时选用哪种语句,让你在编程时更加得心应手。无论面对何种挑战,都能找到最适合的解决方案。
27 1
|
1月前
|
搜索推荐 Java 程序员
在Java编程的旅程中,条件语句是每位开发者不可或缺的伙伴,它如同导航系统,引导着程序根据不同的情况做出响应。
在Java编程中,条件语句是引导程序根据不同情境作出响应的核心工具。本文通过四个案例深入浅出地介绍了如何巧妙运用if-else与switch语句。从基础的用户登录验证到利用switch处理枚举类型,再到条件语句的嵌套与组合,最后探讨了代码的优化与重构。每个案例都旨在帮助开发者提升编码效率与代码质量,无论是初学者还是资深程序员,都能从中获得灵感,让自己的Java代码更加优雅和专业。
13 1
|
1月前
|
Java
在Java编程的广阔天地中,条件语句是控制程序流程、实现逻辑判断的重要工具。
在Java编程中,if-else与switch作为核心条件语句,各具特色。if-else以其高度灵活性,适用于复杂逻辑判断,支持多种条件组合;而switch在多分支选择上表现优异,尤其适合处理枚举类型或固定选项集,通过内部跳转表提高执行效率。两者各有千秋:if-else擅长复杂逻辑,switch则在多分支选择中更胜一筹。理解它们的特点并在合适场景下使用,能够编写出更高效、易读的Java代码。
29 1
|
26天前
|
数据采集 人工智能 监控
【Azure 应用程序见解】Application Insights Java Agent 3.1.0的使用实验,通过修改单个URL的采样率来减少请求及依赖项的数据采集
【Azure 应用程序见解】Application Insights Java Agent 3.1.0的使用实验,通过修改单个URL的采样率来减少请求及依赖项的数据采集
|
27天前
|
Java jenkins Shell
还有人不会启动JAVA程序
还有人不会启动JAVA程序
13 0
|
28天前
|
Java 调度
|
28天前
|
监控 Java API
如何从 Java 程序中查找内存使用情况
【8月更文挑战第22天】
16 0
|
28天前
|
Java