当前位置:   article > 正文

Linux项目开发—电子相册_ubantu虚拟机电子相册的代码

ubantu虚拟机电子相册的代码

1.简述:电子相册,开发一个在ARM9开发板上的电子相册,实现图片的播放;

2.工具、材料:电脑(带有Ubuntu等系列Linux系统)、ARM9系列开发板、串口线一根、串口通信软件SecureCRT;

3.基本流程:

a.编写好源代码后在Ubuntu上编译为arm指令的可执行文件;a1:Linux下编译一般用gcc,基本用法为:gcc example.c  -o out; a2:这样编译出来的可执行文件还不能直接在linux上执行,需要赋予权限:chmod +x out (+x  —— -x);a3:执行源程序:./out  ;

b.经过a编译出来的可执行文件还是只能在电脑上执行,不能再arm开发板上面执行,这是因为arm和intel的汇编代码和指令集不一样,则需要通过使用gcc另一个方法:arm-linux-gcc example.c -o out ;

c.编写好可在arm上执行的文件后则需要导入到开发板上,通过串口线连接开发板和电脑,打开SecureCRT,点击连接,选择对应的com接口,连接好后传输即可;再经过a2 a3;

 图1:效果展示

4.系列知识补充:

a.常用linux指令:除3中提到的几个外,补充如下  a1: cd   cd  / 跳转根目录   cd 文件夹 跳转到指定文件夹     note:可以只输入文件夹前几个字符用TAB补齐;a2:ls  显示当前文件夹下的文件, ls -l  查看详细信息;a3:su 切换用户  直接su 切换管理员root用户 ,su 用户名 切换对应用户,   note:有些可能会出现密码错误无法切换root用户,sudo passwd root 改一下密码,一般都可以解决; a4: rm   例如删库跑路指令: rm -rf /*   ,没事删删玩还可以,别删习惯了-_~; a5: mkdir 创建目录 ,对应删除目录:rmdir   note:文件夹不能和文件同名字的,这个在win下面也是对得;  a6:man  这是一个厉害的命令,可以man许多东西  note:  q退出,n、N搜索; a7:快捷键 ctrl c:退出正在执行的文件;ctrl l 清屏;

b.linux的文件:例如屏幕文件:/dev/fb0,使用方法同样是open,write,close;对触摸屏操作,获取触摸轨迹方向;

c.图片及播放:在这里我们采用bmp格式图片,即位图,这种图片是没有压缩的,读取既显示,采用双向循环链表把图片文件链接起来,根据获取到的触摸事件手指滑动方向来决定链表移动方向;

5.部分代码及实现:

  1. 1 头文件声明
  2. #include<stdio.h>
  3. #include<sys/types.h>
  4. #include<sys/stat.h>
  5. #include<fcntl.h>
  6. #include<unistd.h>
  7. #include <sys/mman.h>
  8. #include<linux/input.h>
  9. #include<stdlib.h>
  10. #include<string.h>
  1. 2 定义各种变量
  2. int fd_lcd,*plcd;//屏幕文件,映射
  3. int fd_bmp;//图片文件
  4. 3 相关函数定义
  5. 1.对一个像素点进行操作,显示颜色
  6. void lcd_draw_point(int x,int y,int color)//写像素点函数
  7. {
  8. if(x>=800||y>=480)//屏幕大小为480*800,超过范围输出显示超界并返回
  9. {
  10. printf("point limited\n");
  11. return;
  12. }
  13. *(plcd+800*y+x)=color;//对应点进行赋值,显示对应颜色
  14. }
  15. 2.对全屏进行颜色刷新为指定颜色
  16. void lcd_clean(int color) //填充指定颜色
  17. {
  18. int x,y;
  19. for(y=0;y<480;y++)
  20. {
  21. for(x=0;x<800;x++)
  22. {
  23. lcd_draw_point(x,y,color);在全屏像素点逐个调用写像素点函数,显示指定颜色
  24. }
  25. }
  26. }
  27. 3.对图片读取写入到屏幕文件显示出来,及显示动效
  28. void draw_pic(struct node * Q)//画图片
  29. {
  30. xg++;//xg为图片显示动画效果,在这里设定3种效果,通过xg自加再对3求余对应各个效果
  31. printf("\n\n%s\n\n",Q->picname);
  32. fd_bmp=open(Q->picname,O_RDWR);//打开图片文件,Q->picname为链表元素值,图片名
  33. if(fd_bmp == -1)//打开屏幕失败的返回值是-1
  34. {
  35. printf("open bmp error\n");
  36. return ;
  37. }
  38. char buf[800*450*3+54];//对应图片文件字节数
  39. read(fd_bmp, buf, 800*450*3+54);//图片的颜色读入到buf数组
  40. close(fd_bmp);//关闭图片文件
  41. char b,g,r;
  42. int color,i,x,y;
  43. if(xg%3==0)//打印效果1,效果原理为按部分显示,将图片分为几个部分逐步显示出来,为突出动态效果,每个显示段中间使用暂停。
  44. {
  45. i = 0;
  46. for(y=50;y>=0;y--)
  47. {
  48. for(x=0;x<800;x++)
  49. {
  50. b = buf[54+i];
  51. g = buf[55+i];
  52. r = buf[56+i];
  53. color = (r<<16) | (g<<8) | b;
  54. lcd_draw_point(x,y,color);//一个个显示颜色
  55. i+=3;
  56. }
  57. }
  58. …………
  59. usleep(200);//暂停一会,毫秒级别
  60. i = 0;
  61. for(y=250;y>=0;y--)
  62. {
  63. for(x=0;x<800;x++)
  64. {
  65. b = buf[54+i];
  66. g = buf[55+i];
  67. r = buf[56+i];
  68. color = (r<<16) | (g<<8) | b;
  69. lcd_draw_point(x,y,color);
  70. i+=3;
  71. }
  72. }
  73. usleep(200);
  74. }
  75. }
  76. 4.根据手指滑动返回的参数控制链表顺序并将传入draw_pic()子程序显示相应的图片
  77. int touch(int f)//传递触摸方向的值和链表
  78. {
  79. struct node * U;
  80. U=L;
  81. if(f==1)
  82. {
  83. fd_lcd=open("/dev/fb0",O_RDWR);//打开屏幕文件
  84. if(fd_lcd= = -1)//打开失败返回-1
  85. {
  86. printf("open fd_lcd error\n");
  87. return -1;
  88. }
  89. plcd=mmap(NULL,800*480*4,PROT_WRITE | PROT_READ, MAP_SHARED,fd_lcd,0);//把文件或设备映射到内存中,操作内存的数据就相当于操作屏幕
  90. if(plcd == MAP_FAILED)
  91. {
  92. printf("mmap failed\n");
  93. return -1;
  94. }
  95. printf("mmap success\n");
  96. printf("shun xu \n");
  97. L=U->next;
  98. draw_pic(L);
  99. printf("shun xu \n");
  100. munmap(plcd,800*480*4);
  101. close(fd_lcd);
  102. return 1;
  103. }
  104. if(f==2)
  105. {
  106. fd_lcd=open("/dev/fb0",O_RDWR);//打开屏幕文件
  107. if(fd_lcd==-1)
  108. {
  109. printf("open fd_lcd error\n");
  110. return -1;
  111. }
  112. plcd=mmap(NULL,800*480*4,PROT_WRITE | PROT_READ, MAP_SHARED,fd_lcd,0);
  113. if(plcd == MAP_FAILED)
  114. {
  115. printf("mmap failed\n");
  116. return -1;
  117. }
  118. printf("mmap success\n");
  119. printf("ni xu \n");
  120. L=U->pre;
  121. draw_pic(L);
  122. printf("ni xu \n");
  123. munmap(plcd,800*480*4);
  124. close(fd_lcd);
  125. return 1;
  126. }
  127. }

附:设计报告、 源代码

 

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/article/detail/47899
推荐阅读
相关标签
  

闽ICP备14008679号