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

儿童摄影网站源码国家免费培训机构

儿童摄影网站源码,国家免费培训机构,wordpress 关站,哪些网站可以注册邮箱MATLAB交互式贝塞尔曲线演示 以下是一个MATLAB交互式贝塞尔曲线演示代码,允许用户通过点击界面来添加控制点并实时查看贝塞尔曲线的变化: function interactive_bezier()% 创建图形窗口fig figure(Name,交互式贝塞尔曲线演示, NumberTitle,off);ax a…

MATLAB交互式贝塞尔曲线演示

以下是一个MATLAB交互式贝塞尔曲线演示代码,允许用户通过点击界面来添加控制点并实时查看贝塞尔曲线的变化:

function interactive_bezier()% 创建图形窗口fig = figure('Name','交互式贝塞尔曲线演示', 'NumberTitle','off');ax = axes('Parent', fig);title(ax, '点击添加控制点 (右键结束)');xlabel(ax, 'X轴');ylabel(ax, 'Y轴');grid(ax, 'on');hold(ax, 'on');axis(ax, [0 10 0 10]);% 初始化控制点controlPoints = [];bezierCurve = [];% 设置鼠标点击回调函数set(fig, 'WindowButtonDownFcn', @addControlPoint);% 添加控制点函数function addControlPoint(~, ~)% 获取点击位置pt = get(ax, 'CurrentPoint');x = pt(1,1);y = pt(1,2);% 检查是否是右键点击 (结束)if strcmp(get(fig, 'SelectionType'), 'alt')if size(controlPoints, 1) >= 2% 结束添加,允许拖动控制点set(fig, 'WindowButtonDownFcn', @selectControlPoint);title(ax, '可以拖动控制点 (右键清除)');endreturn;end% 添加新控制点,垂直拼接controlPoints = [controlPoints; x, y];% 绘制控制点和连线cla(ax);plot(ax, controlPoints(:,1), controlPoints(:,2), 'ro-', 'MarkerFaceColor', 'r');% 如果有足够点,绘制贝塞尔曲线if size(controlPoints, 1) >= 2updateBezierCurve();endend% 更新贝塞尔曲线函数function updateBezierCurve()% 计算贝塞尔曲线t = linspace(0, 1, 100)';n = size(controlPoints, 1) - 1;curve = zeros(length(t), 2);for i = 0:n% 计算伯恩斯坦多项式B = nchoosek(n,i) * (t.^i) .* ((1-t).^(n-i));curve = curve + B .* controlPoints(i+1,:);end% 绘制曲线if ~isempty(bezierCurve)delete(bezierCurve);endbezierCurve = plot(ax, curve(:,1), curve(:,2), 'b-', 'LineWidth', 2);end% 选择控制点函数function selectControlPoint(~, ~)% 检查是否是右键点击 (清除所有点)if strcmp(get(fig, 'SelectionType'), 'alt')controlPoints = [];cla(ax);set(fig, 'WindowButtonDownFcn', @addControlPoint);title(ax, '点击添加控制点 (右键结束)');return;end% 获取点击位置pt = get(ax, 'CurrentPoint');x = pt(1,1);y = pt(1,2);% 查找最近的控制点if ~isempty(controlPoints)distances = sqrt((controlPoints(:,1)-x).^2 + (controlPoints(:,2)-y).^2);[~, idx] = min(distances);% 设置拖动回调函数set(fig, 'WindowButtonMotionFcn', {@dragControlPoint, idx});set(fig, 'WindowButtonUpFcn', @stopDrag);endend% 拖动控制点函数function dragControlPoint(~, ~, idx)% 获取当前鼠标位置pt = get(ax, 'CurrentPoint');x = pt(1,1);y = pt(1,2);% 更新控制点位置controlPoints(idx,:) = [x, y];% 重绘cla(ax);plot(ax, controlPoints(:,1), controlPoints(:,2), 'ro-', 'MarkerFaceColor', 'r');updateBezierCurve();end% 停止拖动函数function stopDrag(~, ~)set(fig, 'WindowButtonMotionFcn', '');set(fig, 'WindowButtonUpFcn', '');end
end

使用说明

  1. 运行上述代码将创建一个交互式图形窗口
  2. 添加控制点:用鼠标左键点击图形区域添加控制点
  3. 结束添加:右键点击结束控制点添加阶段
  4. 拖动控制点:在结束添加后,可以点击并拖动现有控制点
  5. 重置:右键点击清除所有控制点并重新开始

运行结果:
在这里插入图片描述

贝塞尔曲线原理

这段代码实现了n阶贝塞尔曲线的计算,使用伯恩斯坦多项式:

B ( t ) = ∑ i = 0 n ( n i ) ( 1 − t ) n − i t i P i , t ∈ [ 0 , 1 ] \mathbf{B}(t) = \sum_{i=0}^n \binom{n}{i} (1-t)^{n-i} t^i \mathbf{P}_i, \quad t \in [0,1] B(t)=i=0n(in)(1t)nitiPi,t[0,1]

其中:

  • P i \mathbf{P}_i Pi 是第 i i i 个控制点(向量)。
  • ( n i ) \binom{n}{i} (in) 是二项式系数(组合数)。

曲线会实时更新以反映控制点的变化。

您可以将此代码保存为.m文件并在MATLAB中运行,或者直接在命令窗口中执行。

http://www.zhongyajixie.com/news/22564.html

相关文章:

  • 公司网站代做关键词搜索指数查询工具
  • 修改wordpress中的 功能 小工具网站编辑seo
  • 东莞定制网站开发什么是白帽seo
  • 厦门网站建设开发福州百度网站快速优化
  • flarum整合wordpress厦门专业做优化的公司
  • 这几年做那个网站致富线上营销手段有哪些
  • seo怎么做自己的网站百度平台客服怎么联系
  • 网站设计建设公司网络营销师有前途吗
  • 深圳做网站佰达科技三十如何免费发布广告
  • 怎么做军事小视频网站成都网络营销公司
  • 深圳龙华鸿宇大厦网站建设网络营销应用方式
  • 视频网站不赚钱为什么还做淘宝运营团队怎么找
  • 做水果为主的b2c网站有哪些哪个平台可以免费推广
  • 南通网站推广公司seo学习
  • wordpress开启redis西安网络优化哪家好
  • 上海企业免费网站建设百度推广登陆平台
  • 百度网盟如何选择网站网站营销推广
  • 青岛建设集团股份有限公司广州seo关键词
  • 楼凤网站怎么做的韩国今日特大新闻
  • wordpress 党建 主题沈阳百度seo排名优化软件
  • 长沙 直播网站建设短视频seo营销
  • 个人soho要怎么做企业网站提交网址给百度
  • 工装公司名字怎么起培训机构seo
  • 在线旅游网站建设方案北京seo推广外包
  • 政府网站建设会议纪要百度竞价是seo还是sem
  • 博客网站模板二十个优化
  • 怎么看网站开发语言是哪种百度长尾关键词挖掘工具
  • 做网站好的网络公司电销系统软件排名
  • 什么系统做网站好高质量内容的重要性
  • 找人做时时彩网站搜索广告排名