计算机图像学实验-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健康检查监控全过程

《springboot健康检查监控全过程》文章介绍了SpringBoot如何使用Actuator和Micrometer进行健康检查和监控,通过配置和自定义健康指示器,开发者可以实时监控应用组件的状态,... 目录1. 引言重要性2. 配置Spring Boot ActuatorSpring Boot Act

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

java如何分布式锁实现和选型

《java如何分布式锁实现和选型》文章介绍了分布式锁的重要性以及在分布式系统中常见的问题和需求,它详细阐述了如何使用分布式锁来确保数据的一致性和系统的高可用性,文章还提供了基于数据库、Redis和Zo... 目录引言:分布式锁的重要性与分布式系统中的常见问题和需求分布式锁的重要性分布式系统中常见的问题和需求

SpringBoot基于MyBatis-Plus实现Lambda Query查询的示例代码

《SpringBoot基于MyBatis-Plus实现LambdaQuery查询的示例代码》MyBatis-Plus是MyBatis的增强工具,简化了数据库操作,并提高了开发效率,它提供了多种查询方... 目录引言基础环境配置依赖配置(Maven)application.yml 配置表结构设计demo_st

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

el-select下拉选择缓存的实现

《el-select下拉选择缓存的实现》本文主要介绍了在使用el-select实现下拉选择缓存时遇到的问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录项目场景:问题描述解决方案:项目场景:从左侧列表中选取字段填入右侧下拉多选框,用户可以对右侧