当前位置: 首页 > wzjs >正文

wordpress建站购买营销策划的六个步骤

wordpress建站购买,营销策划的六个步骤,代做底单的网站,wordpress分类目录显示列表模式使用 C/OpenCV 实时播放火柴人爱心舞蹈动画 本文将介绍如何使用 C/OpenCV 库实时创建一个动画窗口:一个火柴人捧着爱心跳舞,同时另一个爱心从远处飞来并逐渐变大。动画会实时在 OpenCV 窗口中播放,直到用户按下按键退出。 准备工作 确保你…

使用 C++/OpenCV 实时播放火柴人爱心舞蹈动画

本文将介绍如何使用 C++/OpenCV 库实时创建一个动画窗口:一个火柴人捧着爱心跳舞,同时另一个爱心从远处飞来并逐渐变大。动画会实时在 OpenCV 窗口中播放,直到用户按下按键退出。
在这里插入图片描述

准备工作

确保你的系统上已经安装了 OpenCV 库,并且配置好了 C++ 的编译环境。

C++ 实时动画代码

以下代码会创建一个窗口并直接在其中循环播放动画。

stickman_heart_realtime.cpp:

#include <iostream>
#include <vector>
#include <cmath>
#include <string>
#include <opencv2/opencv.hpp>
#ifndef M_PI
const double M_PI = 3.14159265358979323846;
#endif
using namespace cv;
using namespace std;// --- 动画参数 ---
const int WIDTH = 800;
const int HEIGHT = 600;
const int FPS = 30; // 动画帧率 (Frames Per Second)
const Scalar BG_COLOR = Scalar(28, 28, 28); // 深灰色背景
const Scalar STICKMAN_COLOR = Scalar(255, 255, 255); // 白色火柴人
const Scalar HEART_COLOR = Scalar(70, 70, 255); // 红色爱心 (BGR)
const int STICKMAN_SCALE = 40;
const Point STICKMAN_POS(WIDTH / 3, HEIGHT - 2 * STICKMAN_SCALE);/*** @brief 绘制火柴人* @param img 要绘制的图像* @param pos 火柴人的基准位置 (脚底中心)* @param scale 控制火柴人大小* @param angle 身体的摆动角度*/
void drawStickman(Mat& img, Point pos, int scale, double angle = 0.0) {Point head_center = pos - Point(0, scale * 2);circle(img, head_center, scale / 2, STICKMAN_COLOR, 3, LINE_AA);Point body_top = head_center + Point(0, scale / 2);Point body_bottom = body_top + Point(0, scale);line(img, body_top, body_bottom, STICKMAN_COLOR, 3, LINE_AA);// 摇摆的手臂Point arm_joint = body_top + Point(0, scale / 10);Point arm_left = arm_joint + Point(-scale * 0.7 * cos(angle), scale * 0.7 * sin(angle));Point arm_right = arm_joint + Point(scale * 0.7 * cos(angle), scale * 0.7 * sin(angle));line(img, arm_joint, arm_left, STICKMAN_COLOR, 3, LINE_AA);line(img, arm_joint, arm_right, STICKMAN_COLOR, 3, LINE_AA);// 摇摆的腿Point leg_left = body_bottom + Point(-scale * 0.8* 1, scale * 0.8 * 1);Point leg_right = body_bottom + Point(scale * 0.8 *1, scale * 0.8 * 1);line(img, body_bottom, leg_left, STICKMAN_COLOR, 3, LINE_AA);line(img, body_bottom, leg_right, STICKMAN_COLOR, 3, LINE_AA);
}/*** @brief 绘制实心爱心* @param img 要绘制的图像* @param center 爱心中心点* @param radius 爱心大小*/
void drawHeart(Mat& img, Point center, int radius) {vector<Point> heart_points;for (double t = 0; t <= 2 * M_PI; t += 0.01) {double x = center.x + radius * 1.2 * sin(t) * sin(t) * sin(t);double y = center.y - radius * (1.1 * cos(t) - 0.4 * cos(2 * t) - 0.2 * cos(3 * t) - 0.1 * cos(4 * t));heart_points.push_back(Point(x, y));}fillPoly(img, vector<vector<Point>>{heart_points}, HEART_COLOR, LINE_AA);
}int main() {// 在循环外创建窗口string winName = "Stickman Heart Dance";namedWindow(winName, WINDOW_AUTOSIZE);int frame = 0;// 动画主循环while (true) {// 1. 创建每一帧的画布Mat img(HEIGHT, WIDTH, CV_8UC3, BG_COLOR);// 2. 计算动画参数// 火柴人跳舞动画 (身体和四肢摇摆)double dance_angle = sin(2 * M_PI * frame / (FPS * 2.0)) * 0.8; // 摇摆角度drawStickman(img, STICKMAN_POS, STICKMAN_SCALE, dance_angle);// 火柴人手中捧着的爱心,随着身体跳动double bounce = sin(2 * M_PI * frame / (FPS * 1.0)) * 5;Point holding_heart_offset = Point(0, -STICKMAN_SCALE * 2.5 + bounce);drawHeart(img, STICKMAN_POS + holding_heart_offset, STICKMAN_SCALE / 3);// 飞过来的爱心动画int animation_duration = FPS * 5; // 动画总时长为5秒if (frame < animation_duration) {double progress = static_cast<double>(frame) / animation_duration;// 初始大小和最终大小double start_radius = STICKMAN_SCALE * 0.1;double end_radius = STICKMAN_SCALE * 2.5;// 初始位置和最终位置Point start_pos(WIDTH * 0.9, HEIGHT * 0.2);Point end_pos = STICKMAN_POS + Point(STICKMAN_SCALE * 2, -STICKMAN_SCALE * 2.5);// 使用缓动函数 (ease-out) 使动画更自然double ease_progress = 1 - pow(1 - progress, 3);int current_radius = static_cast<int>(start_radius + (end_radius - start_radius) * ease_progress);Point current_pos = start_pos * (1.0 - ease_progress) + end_pos * ease_progress;drawHeart(img, current_pos, current_radius);}// 添加操作提示putText(img, "Press 'q' or ESC to exit", Point(10, 25), FONT_HERSHEY_SIMPLEX, 0.7, Scalar(200, 200, 200), 1, LINE_AA);// 3. 显示当前帧imshow(winName, img);// 4. 控制帧率并等待按键// 计算每帧的延迟时间 (毫秒)int delay = 1000 / FPS;int key = waitKey(delay);// 如果按下 'q' 键或 ESC 键,则退出循环if (key == 'q' || key == 27) {break;}frame++; // 帧计数器增加}// 关闭所有窗口destroyAllWindows();cout << "Animation finished. Window closed." << endl;return 0;
}

代码逻辑解析

  1. 窗口创建 (namedWindow): 在进入主循环之前,我们先创建一个窗口。这样可以避免在每次循环时都重复创建和销毁窗口,提高效率。

  2. 动画主循环 (while(true)): 程序的核心是一个无限循环。在这个循环中,我们不断地生成和显示动画的每一帧。

  3. 实时显示 (imshow): 在循环的内部,我们用 imshow() 函数将绘制好的图像 img 显示到之前创建的窗口中。每次循环都会刷新窗口的内容,从而形成连续的动画。

  4. 控制速度与响应 (waitKey): waitKey(delay) 是实现实时动画的关键。

    • 控制速度: 它会使程序暂停 delay 毫秒。我们通过 1000 / FPS 计算出每帧应该停留的时间,从而精确控制动画的播放速度。
    • 事件处理与响应: 在暂停期间,waitKey 还会处理窗口的事件,比如检测键盘输入。我们将它的返回值存入 key 变量。
  5. 退出条件: 我们检查 key 的值。如果用户按下了 ‘q’ 键(ASCII码)或 Esc 键(ASCII码为 27),while 循环就会通过 break 语句中断,程序随之结束。

如何编译和运行

  1. 保存代码: 将以上代码保存为 stickman_heart_realtime.cpp
  2. 编译 (使用g++):
    g++ stickman_heart_realtime.cpp -o stickman_app `pkg-config opencv4 --cflags --libs`
    
    (如果你的 OpenCV 不是版本4,可以尝试 pkg-config opencv --cflags --libs)
  3. 运行:
    ./stickman_app
    

运行效果

运行程序后,你会看到一个窗口弹出,并开始播放动画:

  • 一个白色的火柴人在深灰色的背景下左右摇摆四肢,模拟跳舞。
  • 他胸前捧着一个红色的小爱心,随着他的舞步上下跳动。
  • 一个更大的爱心从屏幕右上角缓缓飞入,它的轨迹是一条平滑的曲线,并且在飞行过程中体积不断增大,最终停留在火柴人附近。
  • 动画会一直循环播放。

当你想关闭时,请确保窗口是激活状态(用鼠标点击一下窗口),然后按下键盘上的 ‘q’ 键或 Esc 键即可退出程序。

http://www.dtcms.com/wzjs/513932.html

相关文章:

  • 武汉站哪家设计公司什么是网络推广
  • 建视频网站我想做网络推广找谁
  • 平度网站建设公司做销售找客户渠道
  • 如何使用家里电脑做网站服务器销售网站
  • 公司做网站费用记到哪个科目购物网站制作
  • ui培训班多少钱公众号排名优化
  • 电商网站开发总结与感受软文代写服务
  • 做视频网站需要什么空间吗网络广告有哪些形式
  • 广州开发区人才交流服务中心刷关键词优化排名
  • 可以用腾讯企业邮箱域名做网站百度seo优化工具
  • 重庆网站备案大厅搜狗网页版入口
  • 电子网站搜索引擎怎么做关键词优化排名哪家好
  • 做html网站模板下载地址网站推广公司
  • 网站建设的技术难点西安网站建设方案优化
  • wordpress网站迁移教程北京搜索引擎推广服务
  • 网站建设的价值是什么seo优化的主要内容
  • 代理注册公司收费标准淘宝关键词优化怎么弄
  • 餐饮网站建设需求分析免费软文发布平台有哪些
  • 做lgoo的网站一般有哪些各大引擎搜索入口
  • 香港做批发的网站肇庆seo外包公司
  • 网站建设外包包含内容十大免费网站推广平台有哪些
  • 网站建设中如何使用字体杭州百度推广
  • 中国国际贸易单一窗口网站佛山做网站推广的公司
  • 黄骅住房和城乡建设局网站百度怎么做网站
  • 为什么不能用来名字做网站名厦门网站优化公司
  • 网站主体信息南昌seo代理商
  • 个人网站备案号可以做企业网站吗seo怎么做?
  • 美食门户类网站模版seo什么意思简单来说
  • 北京的重要的网站八百客crm登录入口
  • 三亚旅游网站建设做好网络推广的技巧