利用脚本将文字插入到图片或进行多个图片拼接

简介:

最近做一个拼图游戏,因为有十几关,所以测试的时候也是看的两眼冒金星!于是想到在图片上标上数字,直接按数字排序就方便多了。
Linux下有个图片处理工具imagemagick很强大,正适合做这种后台处理图像的工作。

安装方法:

$ sudo aptitude install imagemagick



1、添加文本的命令(折腾了半天才得来的成果):

$ convert -font helvetica  -pointsize 50 -density 65  -fill red -draw "text 0,56 T99"  in.jpg out.jpg


参数解释:

  • convert - imagemagick工具的一个核心命令,用于图片格式转换,缩放,剪切等等
  • -font - 指定字体
  • -pointsize - 字体点阵大小
  • -density - 字体点阵密度
  • -fill - 字体颜色
  • -draw - 'text'表示插入文本,'0,56'表示文本的起始坐标,'T99'表示要显示的文本
  • in.jpg - 输入图片文件名称
  • out.jpg -输入图片文件名称


注意:
'T99'表示要显示的文本,注意这里文本必须以字符开头,文字或下划线或其它字符开头会报错

关于字体类型还可以看这一段解释:

如何用23英寸高的文字注释一个图片?   
先检查有无可缩放字体:
$ xlsfonts -fn '*-0-0-0-0-*' 
 
有则:
$ convert -font '-*-helvetica-*-*-*--300-300-*-*-*-*-iso8859-1' -fill green -draw 'text 50,300 Magick' image.gif annotated.gif
 
# If you have the FreeType support built into ImageMagick,
# just increase your pointsize and/or density:
$ convert -font Helvetica -pointsize 100 -density 300 -fill green -draw 'text 50,300 Magick' image.gif annotated.gi


2、多个图片拼接命令

$ convert -size 500x500 xc:back -draw 'image Over 10,10 200,200 "in.jpg"' out.jpg
$ convert -size 500x500 xc:#cfcfcf -draw 'image Over 10,10 200,200 "in.jpg"' out.jpg


拼接两个640x960图成1280x640片示例:

convert -size 1280x960 xc:#cfcfcf -draw 'image Over 0,0 640,960 "2.jpg"' -draw 'image Over 640,0 640,960 "1.jpg"'   out.jpg


参数说明:

  • -size - 定义的图片尺寸,如果要拼接多图,需要提取计算出最后的尺寸
  • xc - 输出图片背景颜色,两种指定方式看上面示例
  • -draw - 该参数的格式为' image Over 起始坐标 要显示的width与height "输入图片名称"' 输出图片名称


注意:'image Over'关键字不可少,表示添加图片,好像也可以使用'image SrcOver',具体差别不太清楚;起始坐标表示要插入的图片在输出图像中左上角对应的坐标;第二个数值对为在输出图像上要显示的width与height,如果给的不成比例,它会自动调整

至于如何将一张图片叠加到另一张之上,通过上面拼接示例也很容易实现的(~自己去思考~)。

关于imagemagick的更多信息,可以参阅本人很久之前整理(或撰写)的三篇文档:
[1] ImageMagick FAQ摘要:www.mcuos.com/thread-598-1-4.html
[2] ImageMagick简单介绍:www.mcuos.com/thread-596-1-4.html
[3] ImageMagick详细补充:www.mcuos.com/thread-597-1-4.html

本文转自博客园知识天地的博客,原文链接:利用脚本将文字插入到图片或进行多个图片拼接,如需转载请自行联系原博主。


相关文章
|
1月前
|
文字识别 数据挖掘 网络安全
Python实现avif图片转jpg格式并识别图片中的文字
在做数据分析的时候有些数据是从图片上去获取的,这就需要去识别图片上的文字。Python有很多库可以很方便的实现OCR识别图片中的文字。这里介绍用EasyOCR库进行图片文字识别。easyocr是一个比较流行的库,支持超过80种语言,识别率高,速度也比较快。
29 2
|
5月前
|
JavaScript
jQuery动态拼接多张图片并且获取每张图片名称
jQuery动态拼接多张图片并且获取每张图片名称
26 1
|
人工智能 文字识别 API
20行代码教你如何批量提取图片中文字
大家好,我是志斌~ 之前志斌在考研的时候遇到了一个问题,就是要将图片中的文字给提取出来,当时是J哥帮忙搞出来的,现在已经考完研了,也学会了提取方式,现在来给大家分享一下。
687 0
20行代码教你如何批量提取图片中文字
|
开发者
图片与文字的修改| 学习笔记
快速学习图片与文字的修改。
86 0
图片与文字的修改| 学习笔记
|
前端开发
Selenium系列(八) - 截取完整页面和截取指定元素并保存为图片
Selenium系列(八) - 截取完整页面和截取指定元素并保存为图片
509 0
|
程序员
圣诞快乐文字拼接代码
圣诞快乐,文字拼接如何实现?来看看我是如何实现的吧~
107 0
圣诞快乐文字拼接代码
Word文档中插入的图片显示不全、嵌入式图片显示不全解决方法,仅设置图片为单倍行距方法
Word文档中插入的图片显示不全、嵌入式图片显示不全解决方法,仅设置图片为单倍行距方法
650 0
Word文档中插入的图片显示不全、嵌入式图片显示不全解决方法,仅设置图片为单倍行距方法
Halcon打开图片:单个图片以及遍历读取文件夹里的所有图片
Halcon打开图片:单个图片以及遍历读取文件夹里的所有图片
877 0
截取控件并保存为图片(绝对好用)
原文:截取控件并保存为图片(绝对好用) /// /// 截取保存控件为PNG /// /// 你要截取的控件名 public void ScreenShotSave(FrameworkElement pa...
869 0