热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

在Linux上,如何将文本绘制到位图中?-OnLinux,howtodrawatexttoabitmap?

SupposeIhaveallocateda2-Darrayintbitmap[WIDTH][HEIGHT].IwishtolettheLinuxsystemdraw

Suppose I have allocated a 2-D array int bitmap[WIDTH][HEIGHT]. I wish to let the Linux system draw a line of text, say "Hello World.", to this bitmap buffer as if Linux is printing a normal text on screen, so that I can extract the bitmap pattern of the text and combine it with my other bitmap images. So, could you please share a C++ snippet for this purpose that works on Linux? Thanks a lot.

假设我分配了一个二维数组int位图[WIDTH][HEIGHT]。我希望让Linux系统画一条线,说“Hello World”。对于这个位图缓冲区,就好像Linux在屏幕上打印一个普通的文本一样,这样我就可以提取文本的位图模式,并将它与我的其他位图图像合并在一起。那么,您能分享一个c++代码片段,用于Linux上的这一目的吗?非常感谢。

PS: I can find some codes that do the job, but they are on Windows, not Linux. PS2: If you don't happen to have the code, you can teach me how to write the code, but please expect a lot of naive questions on Linux C++ programming to follow.

PS:我可以找到一些代码,但是它们是在Windows上,而不是Linux上。PS2:如果您碰巧没有代码,您可以教我如何编写代码,但是请期待Linux c++编程中的许多天真的问题。

2 个解决方案

#1


2  

You'll need to choose a C or C++ graphics library. Qt and SDL are two good choices.

您需要选择一个C或c++图形库。Qt和SDL是两个不错的选择。

=========================================================================

= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =

If all you want is to draw an image, another choice is libGD (along with the aforementioned Qt and SDL).

如果您想要绘制一个图像,另一个选择是libGD(以及前面提到的Qt和SDL)。

Jere is an example:

Jere就是一个例子:

https://cs.marlboro.edu/code/c/GD_example/GD_example.c

https://cs.marlboro.edu/code/c/GD_example/GD_example.c

include 
#include 

// Dimensions of image in pixels
#define IMAGE_WIDTH  300
#define IMAGE_HEIGHT 300

// The data to display is in a DATA_SIZE x DATA_SIZE array,
// which will have its (left,top)=(x,y) corner at 
// (DATA_TOP, DATA_LEFT) pixels in from the (0,0)=(left,top) pixel.
#define DATA_SIZE    8
#define DATA_LEFT    30
#define DATA_TOP     30

// Position of some blue lines drawn in the image.
#define BORDER       10
#define LEFT         BORDER
#define RIGHT        IMAGE_WIDTH - BORDER
#define TOP          BORDER
#define BOTTOM       IMAGE_HEIGHT - BORDER

// See the bottom of this code for a discussion of some output possibilities.
char*   filename =   "GD_example.png";

// Some values that'll go into the image as shades of gray.
// Range is 0 to 255 (i.e. 8 bits, which is the standard range of intensity).
// To do this sort of thing with floating point data or other data,
// you'd first scale your numbers to be in this 0 to 255 range.
int     data[DATA_SIZE][DATA_SIZE] ={
  {  2,  10,  10,  10,  10,  10,  10,   2},
  { 10,  20,  30,  40,  40,  30,  20,  10},
  { 10,  30, 100, 100, 100, 100,  30,  10},
  { 10,  40, 100, 200, 200, 100,  40,  10},
  { 10,  30, 100, 200, 200, 100,  30,  10},
  { 10,  20, 100, 100, 100, 100,  20,  10},
  { 10,  10,  20,  30,  40,  30,  10,  10},
  {  2,  10,  10,  10,  10,  10,  10,   2}
};
int main(){
  FILE*       outfile;                                  // defined in stdio
  gdImagePtr  image;                                    // a GD image object
  int         white, blue, gray[255];                   // some GD colors 
  int         i, x, y;                                  // array subscripts

  printf("=== GD example ===\n");

  printf("Creating %i by %i image.\n", IMAGE_WIDTH, IMAGE_HEIGHT);
  image = gdImageCreate(IMAGE_WIDTH, IMAGE_HEIGHT);
  // Or image = gdImageCreateTrueColor(IMAGE_WIDTH, IMAGE_HEIGHT);
  //    followed by colors like white=gdTrueColor(255,255,255) that don't
  //    need to refer to any one image's color table.
  white = gdImageColorAllocate(image, 255,255,255);    //  1st is background
  blue  = gdImageColorAllocate(image, 0,0,255);        //  (red,green,blue)
  for (i=0; i<255; i++){
    gray[i] = gdImageColorAllocate(image, i,i,i);
  }

  printf("Drawing some blue lines.\n");
  gdImageLine(image, LEFT,TOP,     RIGHT,TOP,    blue); // draw lines in image
  gdImageLine(image, RIGHT,TOP,    RIGHT,BOTTOM, blue); //  +-----------------+
  gdImageLine(image, RIGHT,BOTTOM, LEFT,BOTTOM,  blue); //  |0,0       WIDTH,0|
  gdImageLine(image, LEFT,BOTTOM,  LEFT,TOP,     blue); //  |0,HEIGHT         |
                                                        //  +-----------------+
  printf("Filling in some gray pixels.\n");
  for (x=0; x

#2


0  

I later used OpenImageIO to accomplish this. The C++ code is as follows:

我后来使用OpenImageIO来实现这一点。c++代码如下:

#include  
#include 
#include 
OIIO_NAMESPACE_USING

const int WIDTH = 256, HEIGHT = 32, CHANNELS = 3;
unsigned char buffer[WIDTH * HEIGHT * CHANNELS];

int main() {
    ImageBuf ib(ImageSpec(WIDTH, HEIGHT, CHANNELS), buffer);
    ImageBufAlgo::render_text(ib, 0 /* x */, 10 /* y */,
        "Hello, world!" /* text to draw */);
    for (int j = 0; j 

The bitmap pattern can be illustrated as the following screenshot (using ib.write("output.tif");):

位图模式如下面的截图所示(使用ibm .write(“output.tif”);

enter image description here

Thank Larry Gritz for helping me out.

谢谢Larry Gritz的帮助。

PS: It is tested on ubuntu 14.04 and g++ 4.8.4. The link option used is -lboost_system -lOpenImageIO.

PS:它是在ubuntu 14.04和g++ 4.8.4上测试的。使用的链接选项是-lboost_system -lOpenImageIO。

More often than not, it is harder to understand a question than to answer it.

通常,理解一个问题比回答一个问题要难得多。


推荐阅读
  • 本文介绍了一个题目的解法,通过二分答案来解决问题,但困难在于如何进行检查。文章提供了一种逃逸方式,通过移动最慢的宿管来锁门时跑到更居中的位置,从而使所有合格的寝室都居中。文章还提到可以分开判断两边的情况,并使用前缀和的方式来求出在任意时刻能够到达宿管即将锁门的寝室的人数。最后,文章提到可以改成O(n)的直接枚举来解决问题。 ... [详细]
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • Linux环境变量函数getenv、putenv、setenv和unsetenv详解
    本文详细解释了Linux中的环境变量函数getenv、putenv、setenv和unsetenv的用法和功能。通过使用这些函数,可以获取、设置和删除环境变量的值。同时给出了相应的函数原型、参数说明和返回值。通过示例代码演示了如何使用getenv函数获取环境变量的值,并打印出来。 ... [详细]
  • C++中的三角函数计算及其应用
    本文介绍了C++中的三角函数的计算方法和应用,包括计算余弦、正弦、正切值以及反三角函数求对应的弧度制角度的示例代码。代码中使用了C++的数学库和命名空间,通过赋值和输出语句实现了三角函数的计算和结果显示。通过学习本文,读者可以了解到C++中三角函数的基本用法和应用场景。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 本文介绍了PE文件结构中的导出表的解析方法,包括获取区段头表、遍历查找所在的区段等步骤。通过该方法可以准确地解析PE文件中的导出表信息。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • 3.223.28周学习总结中的贪心作业收获及困惑
    本文是对3.223.28周学习总结中的贪心作业进行总结,作者在解题过程中参考了他人的代码,但前提是要先理解题目并有解题思路。作者分享了自己在贪心作业中的收获,同时提到了一道让他困惑的题目,即input details部分引发的疑惑。 ... [详细]
author-avatar
简-单贤_917
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有