EasyX的SetWorkingImage ()

简介: SetWorkingImage :设置工作区

SetWorkingImage :设置工作区

SetWorkingImage(&bigimg);
SetWorkingImage(NULL);//回到默认工作区

如果需要对某个 IMAGE 做绘图操作,可以通过该函数将其设置为当前的绘图设备,之后所有的绘图语句都会绘制在该 IMAGE 上面。


简而言之,就是设置某一个特定的区域来进行绘图


比如下面的代码就把图片作为一个工作区


将参数置为 NULL 可恢复对默认绘图窗口的绘图操作。


比如下面的,添加工作区,可以把一张图片分割为多张图片  


image.png

image.png

运行效果,可以发现图片变成分开的了

image.png

代码

/*
可以看看这个视频
【【C语言/C++】项目实战:烟花表白】
https://www.bilibili.com/video/BV1ZA411L7zx?p=2&vd_source=21581d752de8daca00ef38561a7264f6
*/
#include<graphics.h>
#include<easyx.h>
#include<stdio.h>
#include<time.h>
#define NUM 13
struct Jet
{
  int x, y;//烟花弹的坐标  当前的坐标
  int hx, hy;//烟花弹最高的坐标
  bool shoot;//烟花弹的状态(是否发射)
  unsigned long t1, t2, dt;//速度(单位时间dt=t2-t1)
  IMAGE img[2];//两张图片 img[0]-暗色图片 ing[1]-亮色图片 一闪一闪的效果
  byte n : 1;//位段(可以用到CPU里面,n是一个变量 1个位 1/8个字节 n++对于0 1 0 1……
}jet[NUM];     //img[n++]一闪一闪的效果
void load()
{
  srand(time(NULL));
  IMAGE bigimg;//先加载一整张图片
  loadimage(&bigimg, _T("1.jpg"), 200, 50);
  //工作区(就是能看到的窗口)
  SetWorkingImage(&bigimg);
  //分解一张图片为多张图片
  for (int i = 0; i < NUM; i++)
  {
    int n = rand() % 5;//随机得到一个下标
    getimage(&jet[i].img[0],n*20,0,20,50);//
    getimage(&jet[i].img[1],(n+5)*20,0,20,50);
  }
  SetWorkingImage(NULL);//回到默认工作区
}
void init(int i)//初始化
{
  jet[i].x=0;
  jet[i].y=0;
  jet[i].hx=0;
  jet[i].hy=0;
  jet[i].t1=GetTickCount();//获取系统的时间
  jet[i].t2=0;
  jet[i].dt=rand()%10+1;//1ms到10ms之间
  jet[i].n=0;
  jet[i].shoot=false;
  IMAGE bigimg;//先加载一整张图片
  loadimage(&bigimg, _T("1.jpg"), 200, 50);
  //jet[i].img[0];
  //jet[i].img[1];
}
//烟花弹出现的时间间隔
void choise(DWORD& tt1)
{
  DWORD tt2 = GetTickCount();
  if (tt2 - tt1 > 100)
  {
    int i = rand() % NUM;//0-12
    if (jet[i].shoot == false)
    {
      //数据重新规划一下
      jet[i].x = rand()%(1200-20);
      jet[i].y = rand()%(100+600);//600-699
      jet[i].hx = jet[i].x;
      jet[i].hy = rand()%400;//0-399
      jet[i].shoot = true;
      putimage(jet[i].x, jet[i].y, &jet[i].img[jet[i].n]);//只要n++,就会一闪一闪的
    }
    tt1 = tt2;
  }
}
void Shoot()
{
  for (int i = 0; i < NUM; i++)
  {
    jet[i].t2 = GetTickCount();
    if (jet[i].t2 - jet[i].t1 > jet[i].dt && jet[i].shoot == true)
    {
      putimage(jet[i].x, jet[i].y, &jet[i].img[jet[i].n]);//只要n++,就会一闪一闪的
      if(jet[i].y>jet[i].hy)
      {
        jet[i].n++;
        jet[i].y -= 5;//上升的效果
      }
      putimage(jet[i].x, jet[i].y, &jet[i].img[jet[i].n]);
      if (jet[i].y <= jet[i].hy)//到达了最高的高度
      {
        putimage(jet[i].x, jet[i].y, &jet[i].img[jet[i].n]);
        //它的使命完成
        jet[i].shoot = false;//便于重复使用
      }
      jet[i].t1 = jet[i].t2;
    }
  }
}
int main()
{
  initgraph(1200, 800);
  DWORD tt1 = GetTickCount();
  load();
  putimage(100, 100, &jet[5].img[0]);
  putimage(150, 100, &jet[5].img[1]);
  for (int i = 0; i < NUM; i++)
  {
    init(i);
  }
  while (1)
  {
    choise(tt1);
    Shoot();
  }
  getchar();
}

Code over!

相关文章
|
域名解析 缓存 弹性计算
CDN 的操作与使用|学习笔记
快速学习 CDN 的操作与使用
CDN 的操作与使用|学习笔记
|
4月前
|
Linux
Linux系统之cat命令基本使用
Linux系统之cat命令基本使用
1082 10
Linux系统之cat命令基本使用
|
5月前
|
弹性计算
阿里云199元服务器2核4G5M固定带宽,建议企业用户人手一台
阿里云企业专享199元/年服务器,ECS通用算力型u1实例,2核4G、5M带宽、80G ESSD云盘,续费同价,性价比极高。实名认证企业用户均可购,新老用户皆可参与,立即抢购享超值优惠!
302 1
|
6月前
|
人工智能 算法 搜索推荐
优化RAG检索:别只关注模型,关键在于这三方面!
本文从测试开发视角,解析RAG检索模块的五大优化方向:向量化模型、文本分块、检索参数、混合检索及知识库更新。通过建立自动化评测基线与回归验证体系,确保优化效果可量化、可追溯,让测试成为RAG系统迭代的关键支撑。
|
10月前
送福利!FlowBench客户端首批内测邀请函
魔搭AIGC搭子们,集合啦!ModelScope x FlowBench 团队
401 3
|
存储 安全 C++
C++ 原子变量atomic variable
原子变量是 C++11 引入的一种同步机制,用于多线程环境中的无锁、线程安全操作。其操作不可分割,避免了数据竞争和不一致问题。原子变量位于 `&lt;atomic&gt;` 头文件中,支持多种类型如 `std::atomic&lt;T&gt;` 和特化类型。基本用法包括定义原子变量、加载、存储、交换及比较交换操作。内存顺序(如 `std::memory_order_seq_cst`)用于控制内存访问顺序和可见性,适用于不同场景。原子变量常用于线程安全的计数器和标志位等。
|
存储 缓存 Java
深度解密 Python 虚拟机的执行环境:栈帧对象
深度解密 Python 虚拟机的执行环境:栈帧对象
410 13
|
网络安全 开发工具 git
解决 Git 访问 GitHub 时的 SSL 错误
通过上述步骤,可以有效解决 Git 访问 GitHub 时的 SSL 错误。推荐优先更新 CA 证书和正确配置 Git 使用 CA 证书,避免禁用 SSL 验证。如果问题持续,可以切换到 SSH 方式访问 GitHub,确保连接的安全性和稳定性。希望这些内容对您的学习和工作有所帮助。
6650 4
|
安全 算法 Java
【Java小工匠聊密码学】--消息摘要--SHA3算法
1、SHA3概述 1.1 SHA3简介 由于近年来对传统常用Hash 函数如MD4、MD5、SHA0、SHA1、RIPENMD 等的成功攻击,美国国家标准技术研究所(NIST)在2005年、2006年分别举行了2届密码Hash 研讨会;同时于2007年正式宣布在全球范围内征集新的下一代密码Hash算法,举行SHA-3竞赛·新的Hash算法将被称为SHA-3,并且作为新的安全Hash标准,增强现有的FIPS 180-2标准。
5415 0
|
XML 存储 安全
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
1904 0