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

本文主要是介绍计算机图像学实验-Cyrus-Beck算法和梁友栋-Barsky算法(java实现附代码),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实验内容

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实现附代码)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/349355

相关文章

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

JavaSE正则表达式用法总结大全

《JavaSE正则表达式用法总结大全》正则表达式就是由一些特定的字符组成,代表的是一个规则,:本文主要介绍JavaSE正则表达式用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录常用的正则表达式匹配符正则表China编程达式常用的类Pattern类Matcher类PatternSynta

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

java实现docker镜像上传到harbor仓库的方式

《java实现docker镜像上传到harbor仓库的方式》:本文主要介绍java实现docker镜像上传到harbor仓库的方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 前 言2. 编写工具类2.1 引入依赖包2.2 使用当前服务器的docker环境推送镜像2.2

C++20管道运算符的实现示例

《C++20管道运算符的实现示例》本文简要介绍C++20管道运算符的使用与实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录标准库的管道运算符使用自己实现类似的管道运算符我们不打算介绍太多,因为它实际属于c++20最为重要的

Java easyExcel实现导入多sheet的Excel

《JavaeasyExcel实现导入多sheet的Excel》这篇文章主要为大家详细介绍了如何使用JavaeasyExcel实现导入多sheet的Excel,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录1.官网2.Excel样式3.代码1.官网easyExcel官网2.Excel样式3.代码

Java MQTT实战应用

《JavaMQTT实战应用》本文详解MQTT协议,涵盖其发布/订阅机制、低功耗高效特性、三种服务质量等级(QoS0/1/2),以及客户端、代理、主题的核心概念,最后提供Linux部署教程、Sprin... 目录一、MQTT协议二、MQTT优点三、三种服务质量等级四、客户端、代理、主题1. 客户端(Clien

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文