转自 http://blog.chinaunix.net/uid-22666248-id-283558.html

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4. #include <math.h>
  5. #include <stdint.h>
  6. #include <unistd.h>
  7. #include <fcntl.h>
  8. #include <sys/ioctl.h>
  9. #include <sys/mman.h>
  10. #include <asm/page.h>
  11. #include <linux/fb.h>
  12. #define TRUE 1
  13. #define FALSE 0
  14. #define MIN(x,y) ((x)>(y)?(y):(x))
  15. #define MAX(x,y) ((x)>(y)?(x):(y))
  16. typedef struct fbdev{
  17. int fb;
  18. unsigned long fb_mem_offset;
  19. unsigned long fb_mem;
  20. struct fb_fix_screeninfo fb_fix;
  21. struct fb_var_screeninfo fb_var;
  22. char dev[20];
  23. } FBDEV, *PFBDEV;
  24. typedef struct point{
  25. int x;
  26. int y;
  27. int z;
  28. } POINT, *PPOINT;
  29. void draw_dot (PFBDEV pFbdev, POINT p, uint8_t r, uint8_t g, uint8_t b);
  30. void draw_line(PFBDEV pFbdev, POINT p1, POINT p2, uint8_t r, uint8_t g, uint8_t b);
  31. void draw_polygon(PFBDEV pFbdev, uint32_t num, PPOINT array, uint8_t r, uint8_t g, uint8_t b);
  32. void draw_triangle(PFBDEV pFbdev, POINT p1, POINT p2, POINT p3, uint8_t r, uint8_t g, uint8_t b);
  33. void draw_circle(PFBDEV pFbdev, POINT center, uint32_t radius, uint8_t r, uint8_t g, uint8_t b);
  34. void draw_parabola_x(PFBDEV pFbdev, POINT center, int a, uint8_t r, uint8_t g, uint8_t b);
  35. void draw_parabola_y(PFBDEV pFbdev, POINT center, int a, uint8_t r, uint8_t g, uint8_t b);
  36. int fb_open(PFBDEV pFbdev)
  37. {
  38. pFbdev->fb = open(pFbdev->dev, O_RDWR);
  39. if(pFbdev->fb < 0)
  40. {
  41. printf("Error opening %s: %m. Check kernel config\n", pFbdev->dev);
  42. return FALSE;
  43. }
  44. if (-1 == ioctl(pFbdev->fb,FBIOGET_VSCREENINFO,&(pFbdev->fb_var)))
  45. {
  46. printf("ioctl FBIOGET_VSCREENINFO\n");
  47. return FALSE;
  48. }
  49. if (-1 == ioctl(pFbdev->fb,FBIOGET_FSCREENINFO,&(pFbdev->fb_fix)))
  50. {
  51. printf("ioctl FBIOGET_FSCREENINFO\n");
  52. return FALSE;
  53. }
  54. pFbdev->fb_mem_offset = (unsigned long)(pFbdev->fb_fix.smem_start) & (~PAGE_MASK);
  55. pFbdev->fb_mem = (unsigned long int)mmap(NULL, pFbdev->fb_fix.smem_len +
  56. pFbdev->fb_mem_offset,
  57. PROT_READ | PROT_WRITE, MAP_SHARED, pFbdev->fb, 0);
  58. if (-1L == (long) pFbdev->fb_mem)
  59. {
  60. printf("mmap error! mem:%ld offset:%ld\n", pFbdev->fb_mem,
  61. pFbdev->fb_mem_offset);
  62. return FALSE;
  63. }
  64. return TRUE;
  65. }
  66. void fb_close(PFBDEV pFbdev)
  67. {
  68. close(pFbdev->fb);
  69. pFbdev->fb=-1;
  70. }
  71. void fb_memcpy(void *addr, void *color, size_t len)
  72. {
  73. memcpy(addr, color, len);
  74. }
  75. void draw_dot (PFBDEV pFbdev, POINT p, uint8_t r, uint8_t g, uint8_t b)
  76. {
  77. uint32_t offset;
  78. uint8_t color[4];
  79. color[0] = b;
  80. color[1] = g;
  81. color[2] = r;
  82. color[3] = 0x0;
  83. offset = p.y*pFbdev->fb_fix.line_length+4*p.x;
  84. fb_memcpy((void*)(pFbdev->fb_mem + pFbdev->fb_mem_offset + offset), color, 4);
  85. }
  86. void draw_line(PFBDEV pFbdev, POINT p1, POINT p2, uint8_t r, uint8_t g, uint8_t b)
  87. {
  88. POINT p;
  89. int x,y;
  90. for( x=MIN(p1.x,p2.x); x<=MAX(p1.x,p2.x); x++ )
  91. {
  92. y = (p2.y-p1.y)*(x-p1.x)/(p2.x-p1.x) + p1.y;
  93. p.x = x;
  94. p.y = y;
  95. draw_dot(pFbdev, p, r, g, b);
  96. }
  97. }
  98. void draw_triangle(PFBDEV pFbdev, POINT p1, POINT p2, POINT p3, uint8_t r, uint8_t g, uint8_t b)
  99. {
  100. POINT p[3];
  101. p[0] = p1;
  102. p[1] = p2;
  103. p[2] = p3;
  104. draw_polygon(pFbdev, 3, p, r, g, b);
  105. }
  106. void draw_polygon(PFBDEV pFbdev, uint32_t num, PPOINT array, uint8_t r, uint8_t g, uint8_t b)
  107. {
  108. int i;
  109. for(i=0; i<num; i++)
  110. {
  111. draw_line(pFbdev, array[i], array[(i+1)%num], r, g, b);
  112. }
  113. }
  114. void draw_circle(PFBDEV pFbdev, POINT center, uint32_t radius, uint8_t r, uint8_t g, uint8_t b)
  115. {
  116. POINT p;
  117. int x,y,tmp;
  118. for(x=center.x-radius; x<=center.x+radius; x++)
  119. {
  120. p.x = x;
  121. tmp = sqrt(radius*radius -(x-center.x)*(x-center.x));
  122. p.y = center.y + tmp;
  123. draw_dot(pFbdev, p, r, g, b);
  124. p.y = center.y - tmp;
  125. draw_dot(pFbdev, p, r, g, b);
  126. }
  127. for(y=center.y-radius; y<=center.y+radius; y++)
  128. {
  129. p.y = y;
  130. tmp = sqrt(radius*radius - (y-center.y)*(y-center.y));
  131. p.x = center.x + tmp;
  132. draw_dot(pFbdev, p, r, g, b);
  133. p.x = center.x - tmp;
  134. draw_dot(pFbdev, p, r, g, b);
  135. }
  136. }
  137. void draw_parabola_x(PFBDEV pFbdev, POINT center, int a, uint8_t r, uint8_t g, uint8_t b)
  138. {
  139. int x;
  140. POINT p;
  141. for(x=center.x-100; x<center.x+100; x++)
  142. {
  143. p.x = x;
  144. p.y = (x-center.x)*(x-center.x)/a + center.y;
  145. draw_dot(pFbdev, p, r, g, b);
  146. }
  147. }
  148. void draw_parabola_y(PFBDEV pFbdev, POINT center, int a, uint8_t r, uint8_t g, uint8_t b)
  149. {
  150. int y;
  151. POINT p;
  152. for(y=center.y-100; y<center.y+100; y++)
  153. {
  154. p.y = y;
  155. p.x = (y-center.y)*(y-center.y)/a + center.x;
  156. draw_dot(pFbdev, p, r, g, b);
  157. }
  158. }
  159. int main(void)
  160. {
  161. FBDEV fb;
  162. memset(&fb, 0, sizeof(FBDEV));
  163. strcpy(fb.dev, "/dev/fb0");
  164. if(fb_open(&fb)==FALSE)
  165. {
  166. printf("open frame buffer error\n");
  167. return 0;
  168. }
  169. POINT p1, p2, p3;
  170. p1.x = 300;
  171. p1.y = 450;
  172. p2.x = 500;
  173. p2.y = 300;
  174. draw_line( &fb, p1, p2, 0x0, 0xff, 0x0 );
  175. p1.x = 200;
  176. p1.y = 200;
  177. p2.x = 300;
  178. p2.y = 400;
  179. p3.x = 500;
  180. p3.y = 250;
  181. draw_triangle(&fb, p1, p2, p3, 0x0, 0xff, 0x0);
  182. POINT center = { 600, 500, 0 };
  183. int radius = 100;
  184. draw_circle(&fb, center, radius, 0x0, 0xff, 0x0);
  185. center.x = 700;
  186. center.y = 250;
  187. int a = -100;
  188. draw_parabola_x(&fb, center, a, 0x0, 0xff, 0x0);
  189. draw_parabola_x(&fb, center, -a, 0x0, 0xff, 0x0);
  190. draw_parabola_y(&fb, center, a, 0x0, 0xff, 0x0);
  191. draw_parabola_y(&fb, center, -a, 0x0, 0xff, 0x0);
  192. fb_close(&fb);
  193. return 0;
  194. }

Framebuffer 画点,画线,画多边形,画圆相关推荐

  1. Matlab 画多根线,matlab plot画多条不同颜色的线

    在使用matlab画图的时候,有时需要在一个图中画多条线,并且用不同的颜色区分,下面是我的一个demo. matlab代码如下: clear clc close all; kld = [3.9,3.2 ...

  2. 二维几何基础大合集!《计算几何全家桶(一)》(基础运算、点、线、多边形、圆、网格)

    整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的模板整合计划 目录 1.基本运算 1.1 判断正负函数(sgn) 1.2 点积(数量积.内积)(Dot) 1.3 向量积 ...

  3. OpenCV在图像上画线、矩形、椭圆、多边形、填充的多边形、圆、显示文字

    OpenCV在图像上随机画直线.椭圆.多边形.圆.显示文字 代码如下: /*** @file Drawing_2.cpp* @brief Simple sample code*/#include &l ...

  4. OpenGL学习笔记:画点、直线和多边形(第二讲)

    1.关于点  点的大小默认为1个像素,但也可以改变之. 改变的命令为glPointSize,其函数原型如下:  void glPointSize(GLfloat size);  size必须大于0.0 ...

  5. AutoCad-查看坐标数据-画多段线命令-画圆命令-画文字-VBA

    文章目录 1.打开VBA 2.动作录制 3.显示坐标 4.VBA宏 4.1.绘制多段线 4.2.绘制圆 4.3.绘制多个多边形 5.函数过程调用 6.画文字 6.1.绘制文字 6.2.CAD设置文字字 ...

  6. JAVA实现中点画线_实验1-中点画线和Bresenham画线算法的实现

    <实验1-中点画线和Bresenham画线算法的实现>由会员分享,可在线阅读,更多相关<实验1-中点画线和Bresenham画线算法的实现(9页珍藏版)>请在人人文库网上搜索. ...

  7. 18怎么确定板子形状_板绘怎么画线条排线?板绘小白画线不稳怎么办?

    想学习绘画去找不到方法?小编为大家提供一套学习素材~~领取方式在文章最后~~ 很多初学者在刚刚接触板绘的时候经常会因为手不稳而无法控制线条的运用,导致画面显得粗糙,形状或结构不标准,画面花等等问题. ...

  8. viso 画背景框_3分钟漫画教程 | Q版漫画少女线稿,画完暖暖的

    今天就跟sunny一起来画一幅 看上去就很温暖的超可爱少女吧! 教程选自家的绘画教程 本次教程用到的画材有: 铅笔 勾线笔 01 起稿部分 用简单的几何画出人物动态,用正圆表现人物脑袋,然后用小一点的 ...

  9. ArcGIS.Server.9.2.DotNet在ElementGraphicsLayer画点、线、折线、面、圆、矩形的代码

    ArcGIS.Server.9.2.DotNet在ElementGraphicsLayer画点.线.折线.面.圆.矩形的代码:   1public class AddTool:IMapServerTo ...

  10. Sketch小技巧—画出各种星型和多边形的简单方法

    sketch拥有很棒的矢量工具以及基本的形状.这十分有利于任何一项制图的起步,无论是网页设计或是图标的设计,或者其他.在Sketch中你能轻松设 计图层面板,而且在这里我们提供你可能需要的各种操作功能 ...

最新文章

  1. JavaScript 二进制的 AST
  2. OSI,TCP/IP,五层协议的体系结构,以及各层协议
  3. 挖掘管理价值:企业软件项目管理实战
  4. Java---形参个数可变的方法
  5. c语言程序设计算机基础知识,2018春C语言程序设计(合肥工业大学)
  6. php自学建议_如何高效自学PHP?
  7. java.lang.NoSuchMethodError: org.springframework.util.ReflectionUtils.doWithLocalFieldsV
  8. php导出Excel表格(无插件)
  9. MySQL8.0.19解压安装教程
  10. 单片机c语言程序设计实训100例基于pic pdf,单片机C语言程序设计实训100例 基于AVR+Proteus仿真.pdf...
  11. 移动应用商店比较分析
  12. 超市扫码机器服务器系统搭建,超市用的扫码机是怎么个原理?
  13. DOTA高考全国卷A卷
  14. 常用二极管IN4148和单片机驱动的一些关系
  15. java 求最大公因数_三种算法求最大公约数——Java实现 | 学步园
  16. MyBatis12 结果集映射
  17. Unity游戏画面参数解析与应用:垂直同步、动态模糊、抗锯齿
  18. photoshop不能保存bmp格式
  19. 漫画插画绘图工具:MediBangPaintPro for Mac
  20. python循环语句和跳出语句详解

热门文章

  1. 每日一皮:唯一的编码思想!
  2. 自律到极致-人生才精致:第12期
  3. java int 127_Integer类型中奇怪的127和128
  4. php语言与jsp,关于开发语言之PHP JSP与ASP NET对比浅析
  5. c++ 指针的指针参数
  6. Error: unsupported compiler: 9.3.0
  7. jetpack 安装
  8. torch.squeeze()和unsqueeze()
  9. python数组不同地方
  10. pww区域连接特征提取算法