[stm32] 利用uc-gui封装画图和画线函数移植51上的模拟动画
>_<:这里的动画是黄色矩形区域中一个模仿俯视图的起重机运作动画,一个是模仿主视图的吊钩的运动。通过改变初始Init函数中的数据b_x,b_y实现矩形区域的移动。当实时采集时要首先根据起重机的实际情况改变比例,当传感器传来数据时就相当于这里的run函数,只要把传感器数据接收函数和相关函数结合即可。
>_<:main code:
#include "stdlib.h"
#include "GUI.H"
/*
颜色
*/
#define Black 0x000000
#define White 0xFFFFFF
#define Blue 0xFF0000
#define Red 0x0000FF
/*
画矩形区----------改造的和51一样的函数
*/
void Rectangle(int left,int up,int right,int down,U16 color)
{
GUI_SetColor(color);
GUI_DrawHLine(up,left,right);//横线
GUI_DrawHLine(down,left,right);//横线
GUI_DrawVLine(left,up,down);//垂线
GUI_DrawVLine(right,up,down);//垂线
}
/*
画线函数-----------改造的和51一样的函数
*/
void Line(int x0,int y0,int x1,int y1,U16 color)
{
GUI_SetColor(color);
GUI_DrawLine(x0,y0,x1,y1);
}
///////////////////////////////////////////////////////////////////////////
int b_x,b_y,b_l,b_w;//轨道的x,y,长,宽
//大车的位置,老位置,y值,宽,速度,加速度,左限位,右限位
int m_x,m_old_x,m_y,m_l,m_w,m_v,m_a,m_l_limit_p,m_r_limit_p;
//小车的位置,老位置,超出部分,速度,加速度,上限位,下限位
int s_y,s_old_y,s_extre_part,s_v,s_a,s_u_limit_p,s_d_limit_p; int h_x,h_y,h_w;//横梁的x,y和宽
int move_x_v,move_y_v,move_a;//水平移动速度,
int line_x,line_old_x,line_y,line_l,line_old_l;//伸长部分x,老x,y,长,老长
//--------------------------------------------------------------
void init1()
{
b_x=,b_y=,b_l=,b_w=;
m_x=m_old_x=b_x+,m_y=b_y-,m_l=,m_w=,m_v=,m_a=,m_l_limit_p=,m_r_limit_p=b_x+b_w-m_l_limit_p;
s_y=s_old_y=b_y+,s_extre_part=,s_v=,s_a=,s_u_limit_p=b_y+,s_d_limit_p=b_y+b_l-;
}
void init2()
{
h_x=b_x,h_y=b_y+b_l+,h_w=b_w;
move_x_v=s_v*h_w/m_l,move_y_v=,move_a=;
line_x=line_old_x=,line_y=h_y+,line_l=line_old_l=;
}
//---------------------------Draw-------------------------------
void drawBig()
{
Line(b_x,b_y,b_x+b_w,b_y,Black);
Line(b_x,b_y+b_l,b_x+b_w,b_y+b_l,Black);
}//主梁画
void drawMiddle()
{
if(m_x!=m_old_x)Line(m_old_x,m_y,m_old_x,m_y+m_l,White);
Line(m_x,m_y,m_x,m_y+m_l,Blue);
if(m_x!=m_old_x)Line(m_old_x+m_w,m_y,m_old_x+m_w,m_y+m_l,White);
Line(m_x+m_w,m_y,m_x+m_w,m_y+m_l,Blue);
}//画横梁
void drawSmall()
{
if(s_old_y!=s_y || m_x!=m_old_x)Line(m_old_x-s_extre_part,s_old_y,m_old_x+m_w+s_extre_part,s_old_y,White);
Line(m_x-s_extre_part,s_y,m_x+m_w+s_extre_part,s_y,Red);
}//画小车
void draw1()
{
drawBig();//画主梁
drawMiddle();//画横梁
drawSmall();//画小车
}//总画函数
//----------------------------run-----------------------------
void runMiddle()
{
m_old_x=m_x;
m_x+=m_v;
if(m_x+m_w>=m_r_limit_p || m_x<=m_l_limit_p)m_v*=-;//达到警戒线
}//横梁移动
void runSmall()
{
s_old_y=s_y;
line_old_x=line_x;
s_y+=s_v;
line_x+=move_x_v;
if(s_y>=s_d_limit_p || s_y<=s_u_limit_p){
s_v*=-;
move_x_v*=-;
}//达到警戒线
}//小车移动
void run1()
{
runMiddle();
runSmall();
}//运动函数
/////////////////////////////////////////////////////////////////////////////////
//-------------------------draw--------------------------------
void drawGou()
{
if(line_old_x!=line_x || line_old_l!=line_old_l){
Rectangle(line_old_x-,line_y+line_old_l,line_old_x+,line_y+line_old_l+,White);
Line(line_old_x,line_y+line_old_l+,line_old_x,line_y+line_old_l+,White);
Line(line_old_x,line_y+line_old_l+,line_old_x+,line_y+line_old_l+,White);
Line(line_old_x+,line_y+line_old_l+,line_old_x+,line_y+line_old_l+,White);
Line(line_old_x+,line_y+line_old_l+,line_old_x-,line_y+line_old_l+,White);
Line(line_old_x-,line_y+line_old_l+,line_old_x-,line_y+line_old_l+,White);
}
Rectangle(line_x-,line_y+line_l,line_x+,line_y+line_l+,Blue);
Line(line_x,line_y+line_l+,line_x,line_y+line_l+,Black);
Line(line_x,line_y+line_l+,line_x+,line_y+line_l+,Black);
Line(line_x+,line_y+line_l+,line_x+,line_y+line_l+,Black);
Line(line_x+,line_y+line_l+,line_x-,line_y+line_l+,Black);
Line(line_x-,line_y+line_l+,line_x-,line_y+line_l+,Black);
}//画勾,x,y为绳的下端,r为大小
void drawH()
{
Line(h_x,h_y,h_x+h_w,h_y,Black);
}//画横梁
void drawHuaKuai()
{
if(line_old_x!=line_x)Rectangle(line_old_x-*/,line_y-,line_old_x+*/,line_y,White);
Rectangle(line_x-*/,line_y-,line_x+*/,line_y,Blue);
}//画滑块,x,y为绳的上端,r为大小
void drawLine()
{
if(line_old_l!=line_l || line_x!=line_old_x)Line(line_old_x,line_y,line_old_x,line_y+line_old_l,White);
Line(line_x,line_y,line_x,line_y+line_l,Black);
}//画线
void draw2()
{
drawH();
drawHuaKuai();
drawLine();
drawGou();
}
///////////////////////////////////////////////////////////////////////////
//-------------------------draw尺子--------------------------------
void draw0()
{
GUI_SetColor(GUI_YELLOW);
GUI_FillRect(b_x-,b_y-,b_x+b_w+,h_y+);
Rectangle(b_x-,b_y-,b_x+b_w+,h_y+,GUI_BLUE);//画边框
}
///////////////////////////////////////////////////////////////////////////
void Fun(void)//fun里面的Fun函数------一切动画贴图都在此
{
init1();//初始化1画面
init2();//初始化2画面
GUI_SetBkColor(WHITE);
GUI_Clear();
//GUI_DrawBitmap(&bmkk,0,0);
draw0();
while()
{
run1();
line_old_l=line_l;
line_l+=;
if(line_l>)line_l=;
draw1();
draw2();
GUI_Delay();
}
}
[stm32] 利用uc-gui封装画图和画线函数移植51上的模拟动画的更多相关文章
- 画线函数Glib_Line算法的研究
在这里首先先简单把我对函数的功能的理解阐述一下,方便后面的分析:Glib_Line函数实现的功能是通过参数给定(x1,y1,x2,y2,color),来确定起点(x1,y1)和终点(x2,y2)两 ...
- MFC画线功能总结
本文仅用于学习交流,商业用途请支持正版!转载请注明:http://www.cnblogs.com/mxbs/p/6216464.html MFC画线功能要点有二:其一,鼠标按下时记录初始位置为线的起始 ...
- Bezier画线算法
编译器:VS2013 描述:Bezier画线是利用导数相同拼接曲线,使曲线十分光滑,而不是随意拼接观赏性很差 主函数段 #include "stdafx.h" #include&l ...
- matlab练习程序(Bresenham画线)
Bresenham画线算图形学中最基础的知识了,可惜我并没有选修过图形学,所有还是有必要熟悉一下. 上一篇用到的画线函数应该算是数值微分法,也是我最常用的一种方法,不过这种方法似乎并不是很好. 这里的 ...
- 计算机图形学DDA画线法+中点画线法+Bresenham画线法
#include <cstdio> #include <cstring> #include <conio.h> #include <graphics.h> ...
- 利用C语言编辑画图程序的实现方法
不知道大家在进行开发县级电网调度自动化系统的时候,是否都会遇到一个问题就是:要绘制一个电力系统一次接线图.大家都应该知道其实电力系统的一次接线图是较为复杂的,如果想要使用一般的编程方法来进行绘制的话, ...
- altium designer不经过原理图直接在空白pcb上加封装然后画线
如果是复杂点的PCB,建议还是画下SCH,如果PCB只有几个元件,那么可以用这种方法,想不画原理图,直接进行布线,往往是很多初学者最想知道的,但是这也一定不是初学者能学到的.因为你买的书,都是按画PC ...
- H5中画图标签Canvas---画矩形,画线,画圆,渐变色,图形载入
一: 1.鼠标监视坐标值 <!DOCTYPE html> <head> <meta charset=UTF-8> <title>canvas的演示< ...
- 用 eric6 与 PyQt5 实现python的极速GUI编程(系列03)---- Drawing(绘图)(3)-- 画线
[概览] 本文实现如下的程序:(在窗体中绘画出各种不同风格的线条) 主要步骤如下: 1.在eric6中新建项目,新建窗体 2.(自动打开)进入PyQt5 Desinger,编辑图形界面,保存 3.回到 ...
随机推荐
- {Reship}{C#}{GDI+}GDI+画笔,线,区域类型
=================================================================================== This article is ...
- [笔记]Modelsim系列01:编译Altera库的方法
意义:一劳永逸,不用每次对那些包含Quartus II生成文件的工程进行功能仿真时,都需要重新编译一堆东西.节约时间成本. 版本:ModelSim SE 6.5d 打开Modelsim软件,默认会打开 ...
- DIOCP之DEMO学习顺序及达到要求
第一个:ECHO,了解基础网络通讯过程也触发事件 第二个:StringDEMO,理解长字符串发送编码过程 第三个:StreamCoderDEMO,理解粘包的理方式,即数据类型+数据长度+数据流 第四个 ...
- [2015hdu多校联赛补题]hdu5303 Delicious Apples
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5303 题意:在一个长为L的环形路径上种着一些苹果树,告诉你苹果树的位置(题目中以0~L指示坐标)及苹果 ...
- A 浪哥的烦恼 完全背包dp
https://biancheng.love/contest-ng/index.html#/131/problems 首先,去到n点的最小时间是所有数加起来. 然后,如果我1 --- 2,然后再2-- ...
- lr_convert_string_encoding()转码函数
例子:
- Selenium简单介绍
WEB自动化测试:指WEB应用系统从用户界面层面进行的自动化测试.通过用户界面测试内部的业务逻辑. 自身特点:(一)WEB页面上出现的元素有可能具有不确定性: (二)不同操作系统上不同WEB浏览器之间 ...
- 01背包问题:POJ3624
背包问题是动态规划中的经典问题,而01背包问题是最基本的背包问题,也是最需要深刻理解的,否则何谈复杂的背包问题. POJ3624是一道纯粹的01背包问题,在此,加入新的要求:输出放入物品的方案. 我们 ...
- cookie 的“Value”=“xxxxx,xxxxx”部分无效
cookie 的“Value”=“xxxxx,xxxxx”部分无效 在一些网站中有时候会遇到Cookie的值为逗号 但是在.Net中Cookie的值是不能直接使用逗号的 如果使用形如 C#代码 1.C ...
- apache.http.client.HttpClient
前言 HTTP 协议可能是现在 Internet 上使用得最多.最重要的协议了,越来越多的 Java 应用程序需要直接通过 HTTP 协议来访问网络资源.虽然在 JDK 的 java net包中已经提 ...