首页
学习
活动
专区
圈层
工具
发布

【Java AWT 图形界面编程】使用鼠标滚轮缩放 Canvas 画布中绘制的背景图像 ( 绘制超大图像 + 鼠标拖动 + 鼠标滚轮缩放 + 以当前鼠标指针位置为缩放中心 示例 )

一、鼠标滚轮缩放的中心点设置为当前鼠标中心点 - 要点分析 ---- 鼠标指针指向界面中的 Canvas 画布某个位置 , Canvas 画布中绘制着一张超大图片 , 以该位置为中心 , 滑动鼠标滚轮时进行缩放...; 使用鼠标滚轮缩放后 , 在 Canvas 中绘制的图片的尺寸肯定是放大或者缩小了 , 尺寸发生了改变 ; 图片缩放时 , 鼠标指针指向一个位置 , 该位置对应着一个当前 Canvas 画布中的 x...(null) * scale; // 缩放后的图像宽度 double imageHeight = image.getHeight(null) * scale; // 缩放后的图像高度...) * scale; // 缩放后的图像宽度 double imageHeight = image.getHeight(null) * scale; // 缩放后的图像高度...) * scale; // 缩放后的图像宽度 double imageHeight = image.getHeight(null) * scale; // 缩放后的图像高度

3.7K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【Java AWT 图形界面编程】使用小键盘按键缩放 Canvas 画布中绘制的背景图像 ( 键盘按键监听 + 绘制超大图像 + 鼠标拖动 + 鼠标滚轮缩放 + 以当前鼠标指针位置为缩放中心 示例 )

    + 绘制超大图像 + 鼠标拖动 + 鼠标滚轮缩放 + 以当前鼠标指针位置为缩放中心 示例 ---- 在 【Java AWT 图形界面编程】Canvas 中绘制超大图片 ( 使用鼠标拖动查看全图 | 设置...JFrame 窗口自动关闭 | 获取并绘制图片 | 鼠标拖动计算位移 | 画布偏移 ) 博客中 , 绘制了超大图像 , 可以使用鼠标拖动 ; 在 【Java AWT 图形界面编程】使用鼠标滚轮放大缩小..., 移动距离对应的缩放效果也随之缩小 ; 在 【Java AWT 图形界面编程】使用鼠标滚轮放大缩小 Canvas 画布中绘制的背景图像 ( 鼠标滚轮事件监听器 MouseWheelListener...| Canvas 中绘制图像并设置图像大小 ) 博客中 , 使用缩放背景图像的方式 , 实现缩放效果 , 并同时福袋鼠标指针拖拽效果 ; 本博客中实现的案例 , 在上面的基础上 , 添加了鼠标滚轮缩放的中心点设置为当前鼠标中心点...) * scale; // 缩放后的图像宽度 double imageHeight = image.getHeight(null) * scale; // 缩放后的图像高度

    2.4K20

    JAVA通过BufferedImage进行图片的绘制,缩放,裁剪,水印等操作

    缩放图片 /** *@param width: 缩放后的宽度 *@param height: 缩放后的高度 *@param hints: 图像重采样算法的类型 * * hints...参数取值为以下之一(Image 类中的常量): * SCALE_AREA_AVERAGING: 使用 Area Averaging 图像缩放算法; * SCALE_DEFAULT:...使用默认的图像缩放算法; * SCALE_SMOOTH: 选择图像平滑度比缩放速度具有更高优先级的图像缩放算法。...图像等比缩放 * @param srcImageFile 缩放的图片 * @param destImageFile 缩放后的图片 * @param scale 缩放比例...(120, 12, 253, 67); graphics.draw(path); graphics.dispose(); 总结 JAVA操作图片的话算是一个非常冷门的功能了,最多就是图片的缩放,裁剪,水印这三种情况

    13.6K31

    【MATLAB】图像导出 ( 导出绘制的图像 | 图像设置 )

    文章目录 一、导出图像 1、生成的图像 2、复制图形 3、保存 4、另存为 二、复制选项 1、复制选项 2、图形属性 3、导出设置 一、导出图像 ---- 1、生成的图像 2、复制图形 选择 matlab...生成的图形界面 " Figure 1 " 的菜单栏 , " 编辑选项 " , 点击 " 复制图形 " , 可以将图像拷贝到 Word 文档中 ; 打开 Word 文档 , " Ctrl + V "...可以粘贴到 Word 文档中 ; 3、保存 点击工具栏中的保存按钮 , 磁盘形状 ; 界面闪烁以下之后 , 会在代码所在目录 , 生成代码对应的 png 图片 ; 点击 " 打开文件 " 按钮 ,...可以打开生成的 png 图片所在目录 ; 4、另存为 选择 " 菜单栏 / 另存为 " 选项 , 可以选择保存的格式 , 一般选择 png 格式作为导出的图片 ; 另存为的图片 : 二、复制选项...; 3、导出设置 选择 " 菜单栏 / 文件 / 导出设置 " 选项 , 可以弹出导出设置选项 , 通过大小设置 , 可以缩放图像的大小 ; 缩小后的图片 : 原图片 :

    11.2K20

    在Swift中创建可缩放的图像视图

    也许他们想放大、平移、掌握这些图像? 在本教程中,我们将建立一个可缩放、可平移的图像视图来实现这一功能。 计划 他们说,一张图片胜过千言万语--但它不一定要花上一千行代码!...对于我们的可缩放图像视图,我们要做的是让它成为一个可缩放的视图。对于我们的可缩放图像视图,我们将利用UIScrollView的缩放和平移功能。...设置滚动视图 我们需要实际设置我们的滚动视图,使其可缩放和可平移。这包括设置最小和最大的缩放级别,以及指定用户放大时使用的UIView(在我们的例子中,它将是图像视图)。...medium.com/media/46304… 在这里,我们设置最小和最大的缩放级别,确保滚动指示器被隐藏(我们不希望它们破坏我们美丽的图像!)...medium.com/media/56e86… 这很简单--我们想让我们的图像成为缩放和平移时显示的视图,所以我们只是返回我们的imageView。 设置我们的图像 很好!

    8.2K20

    10、图像的几何变换——平移、镜像、缩放、旋转、仿射变换 OpenCV2:图像的几何变换,平移、镜像、缩放、旋转(1)OpenCV2:图像的几何变换,平移、镜像、缩放、旋转(2)数字图像

    但是,在使用向前映射处理几何变换时却有一些不足,通常会产生两个问题:映射不完全,映射重叠 映射不完全 输入图像的像素总数小于输出图像,这样输出图像中的一些像素找不到在原图像中的映射。 ?...要解决上述两个问题可以使用“向后映射”,使用输出图像的坐标反过来推算改坐标对应于原图像中的坐标位置。...从上面也可以看出,向前映射之所以会出现问题,主要是由于图像像素的总数发生了变化,也就是图像的大小改变了。在一些图像大小不会发生变化的变换中,向前映射还是很有效的。...这是向前映射,在缩放的过程改变了图像的大小,使用向前映射会出现映射重叠和映射不完全的问题,所以这里更关心的是向后映射,也就是输出图像通过向后映射关系找到其在原图像中对应的像素。 向后映射关系: ?...对于图像缩放来说,设水平方向的缩放因子为a,垂直方向缩放因子为b,则用仿射矩阵实现图缩放功能的仿射矩阵为: ? 而对于图像旋转来说,设旋转角度为θ,利用仿射变换实现图像旋转操作的仿射矩阵为: ?

    4.4K51

    图像的几何变换——平移、镜像、缩放、旋转、仿射变换 OpenCV2:图像的几何变换,平移、镜像、缩放、旋转(1)OpenCV2:图像的几何变换,平移、镜像、缩放、旋转(2)数字图像处理笔

    但是,在使用向前映射处理几何变换时却有一些不足,通常会产生两个问题:映射不完全,映射重叠 映射不完全 输入图像的像素总数小于输出图像,这样输出图像中的一些像素找不到在原图像中的映射。 ?...要解决上述两个问题可以使用“向后映射”,使用输出图像的坐标反过来推算改坐标对应于原图像中的坐标位置。...从上面也可以看出,向前映射之所以会出现问题,主要是由于图像像素的总数发生了变化,也就是图像的大小改变了。在一些图像大小不会发生变化的变换中,向前映射还是很有效的。...3.图像缩放 图像的缩放指的是将图像的尺寸变小或变大的过程,也就是减少或增加原图像数据的像素个数。简单来说,就是通过增加或删除像素点来改变图像的尺寸。...这是向前映射,在缩放的过程改变了图像的大小,使用向前映射会出现映射重叠和映射不完全的问题,所以这里更关心的是向后映射,也就是输出图像通过向后映射关系找到其在原图像中对应的像素。 向后映射关系: ?

    11.3K31

    图像几何变换(缩放、旋转)中的常用的插值算法

    最邻近插值: 这是一种最为简单的插值方法,在图像中最小的单位就是单个像素,但是在旋转个缩放的过程中如果出现了小数,那么就对这个浮点坐标进行简单的取整,得到一个整数型坐标,这个整数型坐标对应的像素值就是目标像素的像素值...举个例子: 3*3的灰度图像,其每一个像素点的灰度如下所示 我们要通过缩放,将它变成一个4*4的图像,那么其实相当于放大了4/3倍,从这个倍数我们可以得到这样的比例关系: 根据公式可以计算出目标图像中的...然后我们在确定目标图像中的(0,1)坐标与原图像中对应的坐标,同样套用公式: 我们发现,这里出现了小数,也就是说它对应的原图像的坐标是(0,0.75),显示这是错误的,如果我们不考虑亚像素情况,...双线性内插值法计算量大,但缩放后图像质量高,不会出现像素值不连续的的情况。由于双线性插值具有低通滤波器的性质,使高频分量受损,所以可能会使图像轮廓在一定程度上变得模糊。...代码或许有不同写法,实现方式就一种 该算法是对函数 sin x / x 的一种近似,也就是说 原图像对目标图像的影响 等于 目标点对应于原图像点周围 x距离的点,按照 sin x / x 比例

    2.7K30

    二阶牛顿插值在图像缩放中的应用

    摘要 图像缩放是图像处理领域中的一项基本操作,它涉及到改变图像的分辨率以适应不同的显示或存储需求。...二阶牛顿插值作为一种有效的插值方法,因其在保持图像边缘清晰度和减少模糊效应方面的优势而被广泛应用于图像缩放中。本文将详细介绍二阶牛顿插值的基本原理、在图像缩放中的应用方法以及其效果评估。 1....引言 图像缩放技术在图像显示、传输、分析等多个领域中扮演着重要角色。随着数字图像处理技术的发展,对图像缩放质量的要求也越来越高。...二阶牛顿插值在图像缩放中的应用 在图像缩放中,二阶牛顿插值可以用于计算新像素点的值。具体步骤如下: 3.1 水平方向插值 首先,对原始图像进行水平方向的插值计算,以得到中间图像。...参考文献 基于二阶牛顿插值的图像自适应缩放设计及实现 牛顿插值法在图像处理中的运用 一种基于牛顿二阶插值的图像缩放方法与流程

    56410

    EasyAR 3.0切换摄像头画面缩放翻转的问题

    之前一直使用Vuforia做AR项目,现在新公司用EasyAR做项目,需要实现切换摄像头的功能。...1.首先一个问题是如果使用默认前置摄像头初始化,在有的机器上会出现打不开摄像头,或者画面被缩放的问题。...同时有一些奇怪的问题都可以用这种方式规避(不是解决注意) 一定使用后置摄像头初始化,如果你需要默认前置,也一定用后置摄像头初始化,然后马上切换到前置摄像头。...2.Easy切换到前置摄像头画面会被翻转的问题 EasyAR 使用数据流写入的方式进行摄像机渲染,导致我在网上找到的一个翻转摄像机的代码水平翻转失效,但是只要将这个脚本挂在Camera上不用做任何操作就可以规避...EasyAR切换摄像头反转的问题(因为项目年前上线,暂时也没有时间去查看为什么,算是个应急的解决方案吧) 代码: using System; using System.Collections; using

    1.1K20

    FireFox下Canvas使用图像合成绘制SVG的Bug

    我测试过了的,FireFox下面也测试过的。于是我打开火狐浏览器,启动示例,发现是好的,没有问题。 但是小伙伴集成到产品中就有问题。 差别在哪儿呢?...结论已经明显: FireFox浏览器下,用Canvas下绘制绘制SVG图的时候,globalCompositeOperation的设置将不生效。...下面是一段用于测试的代码,ctx.globalCompositeOperation = 'destination-out' 表示用源图像的形状去挖空目标图像。...事情往往就是这样,很多时候,找到问题所在往往比解决问题要难。 解决方案其实很简单 代码中加入判断,判断浏浏览器是否是FireFox。 如果是,则先把svg图片绘制到临时的canvas上面。...后续绘制用临时的canvas替代svg图片。

    1.3K00

    FireFox下Canvas使用图像合成绘制SVG的Bug

    我测试过了的,FireFox下面也测试过的。于是我打开火狐浏览器,启动示例,发现是好的,没有问题。 但是小伙伴集成到产品中就有问题。 差别在哪儿呢?...结论已经明显: FireFox浏览器下,用Canvas下绘制绘制SVG图的时候,globalCompositeOperation的设置将不生效。...下面是一段用于测试的代码,ctx.globalCompositeOperation = 'destination-out' 表示用源图像的形状去挖空目标图像。...事情往往就是这样,很多时候,找到问题所在往往比解决问题要难。 解决方案其实很简单 代码中加入判断,判断浏浏览器是否是FireFox。 如果是,则先把svg图片绘制到临时的canvas上面。...后续绘制用临时的canvas替代svg图片。

    1.2K10

    ECCV 2020 Oral | 可逆图像缩放:完美恢复降采样后的高清图片

    其实,图片的降采样(缩放)可以说是对数字图像最常见的操作了,它的用处多种多样:压缩图片尺寸、节省服务器存储or带宽、适配不同分辨率的屏幕等等。...如何恢复降采样后的图片是图像处理中一个非常有挑战的问题,一直没有被很好的解决。 我们这篇最新工作,就巧妙地尝试从本质上解决这个问题,论文已被ECCV2020收录为Oral 论文。 2。...方法 对降采样后图片的原图求解是一个典型的病态(ill-posed)问题: 现在有一张图片有4个像素,值分别为1,3,5,7。...但以上这些方法都没有从本质上解决病态问题,效果也不尽如人意。因此我们需要更聪明的方法来解决病态问题。...基于DNN的Encoder-Decoder结构对图像进行缩放和还原 刚才提到了病态问题的产生是由于信息的丢失,那么具体是什么信息被丢失了呢?

    67520
    领券