基于Java的不固定长度字符集在指定宽度和自适应模型下图片绘制生成实战

目录

前言

一、需求介绍

1、指定宽度生成

2、指定列自适应生成

二、Java生成实现

1、公共方法

2、指定宽度生成

3、指定列自适应生成

三、总结


前言

在当今数字化与信息化飞速发展的时代,图像的生成与处理技术正日益成为众多领域关注的焦点。从创意设计到数据可视化,从游戏开发到人工智能辅助创作,高效、精准且具有高度适应性的图像生成方案有着广泛而迫切的需求。Java 作为一种强大、稳定且广泛应用的编程语言,在图像绘制领域也发挥着不可忽视的作用。

在GIS领域,比如图例的生成就会面对以上的问题。由于在进行字符标注时无法预测文本的长度,因此我们需要能有一种自适应文本长度的生成方法,但是同时,也有可能我们需要指定一种宽度从而对字符文本进行绘制的需要。如下两图所示:

基于Java的不固定长度字符集在指定宽度和自适应模型下图片绘制生成实战

自适应宽度生成示意图

基于Java的不固定长度字符集在指定宽度和自适应模型下图片绘制生成实战

指定宽度生成示意图

本实战旨在深入探讨基于 Java 的不固定长度字符集在指定宽度和自适应模型下图片绘制生成的方法与技巧。不固定长度字符集为图片绘制带来了独特的挑战与机遇。一方面,其灵活多变的字符组合方式能够创造出丰富多样、极具个性化的图像效果,为创意表达提供了广阔空间;另一方面,如何在保证图像整体协调性与美观性的前提下,合理安排不同长度字符在指定宽度内的布局,实现自适应模型下的高效绘制,需要深入研究与实践。

通过本次实战,我们期望为读者提供一套完整、实用且具有创新性的基于 Java 的图片绘制解决方案,帮助读者提升在图像生成领域的技术能力,激发他们在数字创作方面的灵感与潜力,从而在各自的应用场景中创造出更具价值与吸引力的图像作品,为推动图像技术的发展与应用贡献一份力量。

一、需求介绍

在面向地理空间的图例生成过程,我们通常会遇到以下两种情况:第一种是需要指定宽度,比如要求在宽度为200px的图片中,将指定的文字在图片中生成。第二种就是需要根据指定列,即一行展示几列,然后自适应的生成固定宽度的图片。本节将主要介绍这两个需求。这里我们需要展示的是一些不一定长的字符串集合,模拟展示以下这些地名数据,如下所示:

```java
String[] demoTexts = {
  " 项目管理", "软件开发", "数据分析","人工智能", "云计算", "网络安全",
  "用户体验", "测试验证", "运维部署", "昆明市","曲靖市","玉溪市",
  "保山市","昭通市","丽江市","普洱市","临沧市","楚雄彝族自治州",
  "红河哈尼族彝族自治州","文山壮族苗族自治州","西双版纳傣族自治州",
  "湘西土家族苗族自治州","深圳市","保亭黎族苗族自治县",
  "阿坝藏族羌族自治州","黔西南布依族苗族自治州","克孜勒苏柯尔克孜自治州",
  "双江拉祜族佤族布朗族傣族自治县","积石山保安族东乡族撒拉族自治县","中国石油集团东方地球物理勘探有限责任公司霸州基地管理处居委会",
  "天津市蓟州区京津州河科技产业园管理委员会虚拟社区","窑街煤电集团民勤县瑞霖生态农林有限责任公司生活区","沈阳市于洪区红旗土地股份合作经营有限公司生活区",
  "大理白族自治州","德宏傣族景颇族自治州","怒江傈僳族自治州","迪庆藏族自治州"
};
```

1、指定宽度生成

指定宽度生成,即我们对目标成果的图片宽度是有要求的,比如宽度指定为200px。核心需求如下:

固定总宽度模式

  • 平均分配列宽 :根据总宽度和列数计算每列可用宽度

  • 自动换行 :根据列数自动计算行数

  • 文本截断 :超长文本添加省略号

2、指定列自适应生成

自适应列宽模式

  • 动态计算列宽 :根据每列中最长的条目确定列宽,遍历所有文本,计算每个条目(矩形+间距+文本)的总宽度,确定最大宽度作为图像宽度。

  • 计算高度 :基于行数和字体高度计算总高度

  • 自动换行 :根据列数自动计算行数

  • 保持完整显示 :不截断文本

二、Java生成实现

本小节将根据上面的生成需求来具体讲解如何进行详细的生成。java生成的实现分成三个部分,第一部分是介绍两个公共方法,第二部分介绍如何按照指定宽度生成,第三部分介绍如何进行自适应生成,通过代码实例的方法进行讲解。

1、公共方法

为了方便对对绘制的文字展示得更加美观,这里我们每进行一次绘制就修改画笔的颜色。因此需要一个生成指定颜色的方法,在java中生成Color对象,并且转为十六进制的颜色表示,核心方法如下:

```java
/**
* - 将color转十六进制字符串
* @param color
* @return
*/
public static String Color2String(Color color) {
    // 获取 RGB 颜色值,格式为 0x00RRGGBB
    int rgb = color.getRGB();
    // 将 RGB 转换为十六进制字符串,去掉前两位的透明度部分(如果是纯不透明颜色)
    String hexColor = "#" + Integer.toHexString(rgb & 0xffffff);
    return hexColor;
}
```

根据不同字符串生成均匀分布的颜色方法如下:

```java
// 生成可区分颜色(HSV色环均匀分布)
private static Color[] generateDistinctColors(int count) {
    Color[] colors = new Color[count];
    float goldenRatio = 0.618033988749895f;  // 黄金分割比例
    float saturation = 0.8f;  // 饱和度
    float brightness = 0.9f;  // 亮度
    for (int i = 0; i  processedTexts = new ArrayList<>();
    for (String text : texts) {
        processedTexts.add(truncateText(text, textMaxWidth, fm));
    }

    // 计算总高度
    int rows = (int) Math.ceil((double)texts.length / columns);
    int totalHeight = padding * 2 + rows * (fm.getHeight() + rowSpacing) - rowSpacing;

    // 创建图像
    BufferedImage image = new BufferedImage(totalWidth, totalHeight, BufferedImage.TYPE_INT_ARGB);
    Graphics2D g = image.createGraphics();
    setupGraphics(g, font);

    // 绘制背景
    g.setColor(Color.WHITE);
    g.fillRect(0, 0, totalWidth, totalHeight);

    // 绘制条目
    int yBase = padding + fm.getAscent();
    int[] columnX = new int[columns];
    for (int i = 0; i  0 && fm.stringWidth(text.substring(0, length)) > availableWidth) {
        length--;
    }
    return length > 0 ? text.substring(0, length) + "..." : "";
}
```

生成指定宽度的图片调用方法如下:

```java
// 生成固定宽度图片(400px宽,2列)
BufferedImage fixedImage = createFixedColumnsImage(
     demoTexts, 2, 400,
     new Font("宋体", Font.PLAIN, 12),
     15, 20, 10
);
ImageIO.write(fixedImage, "PNG", new File("D:/fixed_columns_250420.png"));
```

生成的成果图片如下:

基于Java的不固定长度字符集在指定宽度和自适应模型下图片绘制生成实战

3、指定列自适应生成

生成指定列的自适应图片生成的核心方法如下:

```java
// 自适应列宽模式
    public static BufferedImage createAdaptiveColumnsImage(String[] texts, int columns,
                                                          Font font, int padding, 
                                                          int columnSpacing, int rowSpacing) {
        BufferedImage tempImg = new BufferedImage(1, 1, BufferedImage.TYPE_INT_ARGB);
        Graphics2D tempG = tempImg.createGraphics();
        tempG.setFont(font);
        FontMetrics fm = tempG.getFontMetrics();

        final int RECT_SIZE = 10;
        final int ENTRY_SPACING = 5; // 图标与文字间距

        // 生成颜色序列
        Color[] colors = generateDistinctColors(texts.length);
        int index = 0;
        for (String text : texts) {
            texts[index] = Color2String(colors[index]) + " " + text; 
            //processedTexts.add(truncateText(text, textMaxWidth, fm));
            index ++;
        }

        // 计算列宽
        int[] columnWidths = new int[columns];
        for (int i = 0; i  columnWidths[col]) {
                columnWidths[col] = width;
            }
        }

        // 计算总尺寸
        int totalWidth = padding * 2;
        for (int w : columnWidths) {
            totalWidth += w + columnSpacing;
        }
        totalWidth -= columnSpacing; // 最后一列不加间距

        int rows = (int) Math.ceil((double)texts.length / columns);
        int totalHeight = padding * 2 + rows * (fm.getHeight() + rowSpacing) - rowSpacing;

        // 创建图像
        BufferedImage image = new BufferedImage(totalWidth, totalHeight, BufferedImage.TYPE_INT_ARGB);
        Graphics2D g = image.createGraphics();
        setupGraphics(g, font);

        // 绘制背景
        g.setColor(Color.WHITE);
        g.fillRect(0, 0, totalWidth, totalHeight);

        // 绘制条目
        int x = padding;
        int yBase = padding + fm.getAscent();
        int[] columnX = new int[columns];
        for (int i = 0; i

三、总结

以上就是本文的主要内容,本实战旨在深入探讨基于 Java 的不固定长度字符集在指定宽度和自适应模型下图片绘制生成的方法与技巧。不固定长度字符集为图片绘制带来了独特的挑战与机遇。一方面,其灵活多变的字符组合方式能够创造出丰富多样、极具个性化的图像效果,为创意表达提供了广阔空间;另一方面,如何在保证图像整体协调性与美观性的前提下,合理安排不同长度字符在指定宽度内的布局,实现自适应模型下的高效绘制,需要深入研究与实践。

通过本次实战,我们期望为读者提供一套完整、实用且具有创新性的基于 Java 的图片绘制解决方案,帮助读者提升在图像生成领域的技术能力,激发他们在数字创作方面的灵感与潜力,从而在各自的应用场景中创造出更具价值与吸引力的图像作品,为推动图像技术的发展与应用贡献一份力量。行文仓促,定有不足之处,欢迎各位朋友在评论区批评指正,不胜感激。

完整的代码链接如下:Java根据字符串集合生成固定宽度和自适应宽度源码

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/9083.html

(0)
LomuLomu
上一篇 2025 年 5 月 12 日
下一篇 2025 年 5 月 12 日

相关推荐

  • 【Java】还在死磕算法?懂“堆”与“优先级队列”,代码效率飙升

    欢迎 💛点赞 🌟收藏 💫关注 🏆堆 一、🎯堆的定义 堆的概念 堆是一种特殊的完全二叉树,它通过一维数组顺序存储关键码集合K={k0,k1,k2,…,kn-1},并遵循特定的顺序关系来定义。具体来说,若对于任意节点Ki,都满足Ki = 0; parent–) { siftDown(parent, usedSize); } } public void si…

    2024 年 12 月 27 日
    39500
  • 深入解析Java中的嵌套类机制

    探索Java嵌套类的奥秘 📚📚本文将系统性地介绍Java嵌套类的核心概念、应用场景及具体实现方式,帮助开发者全面掌握这一重要特性。内容导航1. 嵌套类基本概念2. 嵌套类的优势分析3. 嵌套类的实践应用🍇实例成员嵌套类🍈类静态嵌套类🍊方法局部嵌套类🍒匿名实现类📚要点回顾 1. 嵌套类基本概念 🥦🥦🥦当某个对象需要包含具有完整结构的辅助对象时,而这些辅助对象仅…

    2025 年 5 月 18 日
    19000
  • 寻找缺失的整数

    11.寻找缺失的整数 题目 在一个无序数组里有99个不重复的正整数,范围是1100,唯独缺少一个1100的整数。然后找出这个缺失的整数。 思路 1.对无序数组,进行升序排序,先判断首位是否为2或99,如果是则得到缺失值,否则,不连续的两个元素中间即为,缺失值。时间复杂度,为排序算法的时间复杂度,空间复杂度为O(1)。代码略 2.求出无序数组的和,用1+2+.…

    未分类 2025 年 1 月 15 日
    55000
  • Java Druid 面试题

    Druid连接池在项目中有哪些优势? 性能优越:Druid采用了高效的连接管理机制,可以快速地创建和回收数据库连接,减少了连接的创建和销毁带来的性能开销。 监控与统计:Druid提供了详细的监控信息,包括连接池的状态、SQL执行的统计信息等,这有助于性能调优和问题诊断。 SQL日志记录:Druid内置了SQL执行日志记录功能,可以记录所有SQL语句的执行情况…

    未分类 2025 年 1 月 10 日
    43000
  • intellij idea使用:激活码与插件问题

    下载 官网下载,不需要下载最新版的,我下载的是2024.2.3,能正常使用激活码 安装教程去网上搜,有一大把 激活码 这里整合了两个靠谱的激活码更新网站,里面会更新免费的激活码,拿来用即可,比在网上搜省很多时间,网上很多都是打广告的,没有有效信息。 https://www.yuque.com/hudies/coding/dm2x3ivmeg9pf3ve ht…

    2024 年 12 月 26 日
    50700

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信