打造酷炫风格的Swing界面(2)

2024-04-27 10:58

本文主要是介绍打造酷炫风格的Swing界面(2),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在上一篇文章中,我们定制了不能拖放界面大小的窗口,但是很多时候,我们都必须能够实现窗口拖拉,但是图片的大小已经固定了,怎么办了?


 

能拖拉的窗口大小

 

在播放器的歌词窗口的窗口时可以拖拉大小的,如图1:

 

图1 拖拉的歌词窗口:

 


 

 

打造能拖拉的定制窗口

 

首先,我们应该想到无论窗口怎么拖拉大小,起四周的四个角的大小是不会变化的,我们把四个角的图片以窗口大小为变量定位在窗口的四个位置,图片素材如下图2;

 

图2:四个角的素材

    

 

 

 

在拖拉的过程中,改变大小的分别是四周的边距,我们可以根据窗口的大小来动态的填充四周的边距;图片素材如图3;

 

图3:四边距的素材

 

        

如下一节的文章中那样,我们扩展一个Border,把上面的图片依次的画上去;代码清单如下:

 

代码清单1:

 

 

其实,在处理剩下的那一个不足以将背景图片铺开的空间的时候,我们在图片单一的情况,事实上另一种处理方式是把图片拉伸开来,如下代码:

 

 

只不过这种方式会再拖拉的时候出现空白的不连贯,原因在于在图片渲染的时候,把内存中的同一张图片重复的绘制要比把一张图片拉伸显示的效率要高得多;

 

接下来,我们就是要在这个没有边框渲染的窗口上实现自己的拖拉大小的功能,当鼠标分别放在左上角,顶部,右上角,右边距,右下角,底部,左下角,左边距八个方位的时候,如下图4;

 

图4:八个方向

 

分别显示八个不同的鼠标的拖拉样式,并且在鼠标按下的时候,记录下初始位置和拖拉方向,在鼠标移动的时候改变窗口大小,在鼠标松开的时候复位标志变量;代码清单2是用于计算这个八个矩形;

 

代码清单2,计算八矩形位置:

 

 

  下面是当鼠标分别处于这8个矩形的时候分别应该显示的鼠标样式和记录下来的状态:

 

代码清单3:

 

 

 

 

 

下面则是根据鼠标是否在这个把8个矩形中来设定状态和鼠标样式;

 

代码清单4:

 

 

当鼠标按下的时候:

 

代码清单5:

 

 

当鼠标移动的时候:

 

代码清单6:

 

 

 

当选择了拖拉下面的边框的时候:

 

代码清单7:

 

 

当选择拖拉左边的边框的时候,这个时候必须保证右边的边的位置是固定不变的:

 

 

代码清单8:

 

 


总结

 

利用了角度拉伸不变,而填充被拉伸的空间来实现一个可拉伸的图片背景窗口,我们可以实现很多绚丽的窗口;

这篇关于打造酷炫风格的Swing界面(2)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.

python编写朋克风格的天气查询程序

《python编写朋克风格的天气查询程序》这篇文章主要为大家详细介绍了一个基于Python的桌面应用程序,使用了tkinter库来创建图形用户界面并通过requests库调用Open-MeteoAPI... 目录工具介绍工具使用说明python脚本内容如何运行脚本工具介绍这个天气查询工具是一个基于 Pyt

Python使用Tkinter打造一个完整的桌面应用

《Python使用Tkinter打造一个完整的桌面应用》在Python生态中,Tkinter就像一把瑞士军刀,它没有花哨的特效,却能快速搭建出实用的图形界面,作为Python自带的标准库,无需安装即可... 目录一、界面搭建:像搭积木一样组合控件二、菜单系统:给应用装上“控制中枢”三、事件驱动:让界面“活”

基于Python+PyQt5打造一个跨平台Emoji表情管理神器

《基于Python+PyQt5打造一个跨平台Emoji表情管理神器》在当今数字化社交时代,Emoji已成为全球通用的视觉语言,本文主要为大家详细介绍了如何使用Python和PyQt5开发一个功能全面的... 目录概述功能特性1. 全量Emoji集合2. 智能搜索系统3. 高效交互设计4. 现代化UI展示效果

VS配置好Qt环境之后但无法打开ui界面的问题解决

《VS配置好Qt环境之后但无法打开ui界面的问题解决》本文主要介绍了VS配置好Qt环境之后但无法打开ui界面的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目UKeLvb录找到Qt安装目录中designer.UKeLvBexe的路径找到vs中的解决方案资源

使用Python创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

基于Python打造一个智能单词管理神器

《基于Python打造一个智能单词管理神器》这篇文章主要为大家详细介绍了如何使用Python打造一个智能单词管理神器,从查询到导出的一站式解决,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 项目概述:为什么需要这个工具2. 环境搭建与快速入门2.1 环境要求2.2 首次运行配置3. 核心功能使用指

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

Python结合PyWebView库打造跨平台桌面应用

《Python结合PyWebView库打造跨平台桌面应用》随着Web技术的发展,将HTML/CSS/JavaScript与Python结合构建桌面应用成为可能,本文将系统讲解如何使用PyWebView... 目录一、技术原理与优势分析1.1 架构原理1.2 核心优势二、开发环境搭建2.1 安装依赖2.2 验