实验内容

1、用Cyrus-Beck算法进行给定直线的裁剪

2、用梁友栋-Barsky算法进行给定直线的裁剪

实验代码

1、用Cyrus-Beck算法进行给定直线的裁剪

//Cyrus-Beck算法
import java.awt.*;
import java.applet.Applet;
public class CyrusBeck extends Applet{double ts = 0, te = 1;public void paint(Graphics g) {// 绘制裁剪窗口g.setColor(Color.pink);int[] xPoints = {200, 84, 318};int[] yPoints = {275, 100, 100};g.drawPolygon(xPoints, yPoints, 3);// 绘制被裁剪直线g.setColor(Color.blue);g.drawLine(0, 120, 400, 120);g.drawLine(0, 180, 400, 180);// 进行裁剪double[][] A = {{200, 275}, {84+1/3, 100}, {318+2/3, 100}};// 计算法向量数组Ndouble[][] N = new double[3][2];for (int i = 0; i < 3; i++) {int next = (i + 1) % 3;double dx = A[next][0] - A[i][0];double dy = A[next][1] - A[i][1];N[i][0] = -dy;N[i][1] = dx;}double[] x = {0, 400};double[] y1 = {120, 120};double[] y2 = {180, 180};g.setColor(Color.orange);Cyrus_Beck(g, A, N, x, y1, ts, te);g.setColor(Color.black);Cyrus_Beck(g, A, N, x, y2, ts, te);}public void Cyrus_Beck(Graphics g, double[][] A, double[][] N, double[] x, double[] y, double ts, double te) {boolean draw = true;int i;double t, dn, nw;for (i = 0; i < 3; i++) {dn = N[i][0] * (x[1] - x[0]) + N[i][1] * (y[1] - y[0]);nw = N[i][0] * (x[0] - A[i][0]) + N[i][1] * (y[0] - A[i][1]);t = -nw / dn;if (dn < 0) {if (t < te) te = t;} else if (t > ts) ts = t;if (ts > te) draw = false;}if (draw) {double xs = (x[1] - x[0]) * ts + x[0];double ys = (y[1] - y[0]) * ts + y[0];double xe = (x[1] - x[0]) * te + x[0];double ye = (y[1] - y[0]) * te + y[0];g.drawLine((int) xs, (int) ys, (int) xe, (int) ye);}
}
}

2、用梁友栋-Barsky算法进行给定直线的裁剪

//梁友栋-Barsky算法
import javax.swing.*;//引入swing包
import java.awt.*;//引入图形软件包awt
class Liang_Barsky extends JPanel {double xL = 100, xR = 200, yT = 200, yB = 100;    //矩形的边所对应的两个x,y坐标boolean visible;double[] x = {100, 300};double[] y = {50, 200};double ts = 0, te = 1;public boolean Liang_Barsky(double[] x, double[] y) {visible = false;double dx, dy;dx = x[1] - x[0];dy = y[1] - y[0];if (clipt(-dx, x[0] - xL))if (clipt(dx, xR - x[0]))if (clipt(-dy, y[0] - yB))if (clipt(dy, yT - y[0]))visible = true;return visible;}public boolean clipt(double r, double s) {double t;this.ts=ts;this.te=te;if (r < 0) {t = s / r;if (t > te) return false;else if (t > ts) ts = t;} else if (r > 0) {t = s / r;if (t < ts) return false;else if (t < te) te = t;} else if (s < 0) return false;return true;}public void paintComponent(Graphics g) {g.setColor(Color.blue);                            //设置绘图颜色drawLine(g, (int) xL, (int) yT, (int) xL, (int) yB);//绘制裁剪窗口drawLine(g, (int) xL, (int) yT, (int) xR, (int) yT);drawLine(g, (int) xL, (int) yB, (int) xR, (int) yB);drawLine(g, (int) xR, (int) yT, (int) xR, (int) yB);g.setColor(Color.red);                              //设置绘图颜色drawLine(g, (int) x[0], (int) y[0], (int) x[1], (int) y[1]);//绘制裁剪前直线if (Liang_Barsky(x, y)) {g.setColor(Color.black);                      //设置绘图颜色double x1 = x[0] + ts * (x[1] - x[0]);double y1 = y[0] + ts * (y[1] - y[0]);double x2 = x[0] + te * (x[1] - x[0]);double y2 = y[0] + te * (y[1] - y[0]);drawLine(g, (int) x1, (int) y1, (int) x2, (int) y2);//绘制裁剪后直线}}void drawLine(Graphics g, int x1, int y1, int x2, int y2) {g.drawLine(x1, y1, x2, y2);}
}

运行结果

1、Cyrus-Beck算法运行结果

2、梁友栋-Barsky算法运行结果

梁友栋-Barsky裁减算法,过几天补充!

梁友栋-Barsky裁减算法已补充。//2023.6.2

计算机图像学实验-Cyrus-Beck算法和梁友栋-Barsky算法(java实现附代码)相关推荐

  1. 计算机图形学:Cohen-Sutherland直线段剪裁算法及梁友栋-Barsky裁剪算法(算法原理及代码实现)

    一.算法实现原理 Cohen-Sutherland直线段剪裁算法: 算法原理: (1)判断线段两端是否都落在窗口内,如果是,则线段完全可见,否则进行下一步 (2)判断线段两端是否都落在窗口外,如果是, ...

  2. java实现梁友栋裁剪算法_梁友栋裁剪算法

    梁友栋裁剪算法 用任意颜色绘制窗口,并用一种颜色绘制线段,利用P181页所示梁友栋裁剪算法对线段进行裁剪.要求能够演示出裁剪过程,裁剪前的图形要绘出,当按下任意按键,绘制出裁剪结果.请使用TC打开源程 ...

  3. 梁友栋-Barsky裁剪算法原理分析

    梁友栋-Barsky算法是一种参数线裁剪算法. 为两个参数方程,为两点的差值,其中的由来是整理参数方程中三角函数的值得出,因为取值需要在裁剪框内,所以u只需要取0~1范围内的就足够. 是结合四条边界线 ...

  4. 计算机图形学 裁剪算法源代码,OpenGL计算机图形学梁友栋裁剪算法实验代码及运行结果.doc...

    OpenGL计算机图形学梁友栋裁剪算法实验代码及运行结果.doc (10页) 本资源提供全文预览,点击全文预览即可全文预览,如果喜欢文档就下载吧,查找使用更方便哦! 14.9 积分  .<计算 ...

  5. 理解梁友栋-Barsky裁剪算法

    学习图形学窗口裁剪算法时,很多教材只是对梁友栋-Barsky裁剪算法过程做了简单的介绍,并没有对原理过多的解释.老而学者如秉烛夜行,用了两三天时间终于搞明白算法原理. 消除指定区域内或区域外的图形部分 ...

  6. [计算机图形学]Python实现梁友栋裁剪算法

    梁友栋算法是很简单的一个裁剪算法,但是只适用于裁剪范围是矩形框并且矩形框边界平行于坐标轴的情况. 实验结果: 完整代码: 注意代码没有写到线是平行和垂直的情况,也没有考虑线不经过框的情况,所以输入的时 ...

  7. openGL-梁友栋-Barsky算法

    代码 // // main.cpp // hw_1_cut_line // // Created by 窦志扬 on 2018/3/11. // Copyright © 2018年 窦志扬. All ...

  8. 基于蜜蜂优化算法优化的卷积神经网络(CNN)图像分类——附代码

    目录 摘要: 1.蜜蜂优化算法: 2. 卷积神经网络(CNN) 输入层 隐含层 输出层 ​3. 本文Matlab代码:​ 摘要: 本文通过蜜蜂优化算法,优化了卷积神经网络(CNN)中的超参数,主要是网 ...

  9. 基于蝗虫(蚱蜢)优化算法优化的支持向量机分类模型及其MATLAB实现-附代码

    基于蝗虫(蚱蜢)优化算法GOA优化的支持向量机分类模型SVM及其MATLAB实现-附代码 文章目录 基于蝗虫(蚱蜢)优化算法GOA优化的支持向量机分类模型SVM及其MATLAB实现-附代码 1. 模型 ...

  10. 计算机图形学常用算法实现9 梁友栋-Barskey裁剪算法

    这个算法的效率比前面提到的Cohen-Sutherland要高 思路是把直线表示为参数方程形式, x= x1+udx y = y1+udy 由xmin<x<xmax ymin<y&l ...

最新文章

  1. 悠然乱弹:聊聊模块化
  2. SQL Date Utility
  3. [Vani有约会]雨天的尾巴 (线段树合并)
  4. 【机器学习】业界干货 | 图解自监督学习,从入门到专家必读的九篇论文
  5. java的算法库_利用Java写开源库 覆盖70多种推荐算法
  6. 控制面板的cpl程序列表
  7. Debian 9 strech 安装 ROS lunar
  8. 演练 创建数据库MySchool 1007 sqlserver
  9. 安卓手机电子书阅读器的使用体验及对比
  10. JavaScript的类的实现
  11. 2019觉得工作很难找?来成都网优谷学点技术吧,小老弟!
  12. Java中的private关键字
  13. C# 生成多张excel 并打包
  14. banner图如何放置
  15. 【7gyy】笔者支招:巧设安全模式防攻击
  16. 程序员写好简历的五大技巧
  17. win10计算器_计算器也能刷Win10,国外大神又现惊人操作
  18. 加菲猫经典语录(中英文对照)
  19. 我国对计算机科学与技术专业人才社会需求,浅谈计算机科学与技术专业应用技术型人才的培养研究论文...
  20. Jetpack Compose 从入门到入门(六)

热门文章

  1. Linux安全-用户密码被暴力破解
  2. umijs中使用useDispatch
  3. 【学习资源】C#初学者学习资源推荐
  4. 为什么不推荐用汇编语言编写GUI应用程序 From Eggache_man
  5. [毕业设计源码]计算机毕业设计JAVA在线玩具租赁系统
  6. iWork Converter for mac(简单易用的iWork文件转换工具)
  7. 阿里云AI可观测母猪是否怀孕 提升母猪产仔量
  8. Java自学日记之网络编程(二):UDP通信实现
  9. xxl - 定时任务
  10. 小米oj题:殊途同归