atitit.GUI图片非规则按钮跟动态图片切换的实现模式总结java .net c# c++ web html js
atitit.GUI图片非规则按钮跟动态图片切换的实现模式总结java .net c# c++ web html js
1.2. 不要边框,如果用自定义图片做按钮背景可以设为 false。 2
2.1. 优先模式:button控件模式+backgroud属性 2
3.4. 重绘button的paint事件(最不推荐,复杂) 3
1. 图片按钮的效果总结
1.1. 按钮图片自动缩放的。
中间走稍微图片大的不要ps调整兰,方便...
1.2. 不要边框,如果用自定义图片做按钮背景可以设为 false。
1.3. 异形按钮
透明空白填空如果你的自定义图片不是矩形或存在空白边距,可以设为 false 使按钮看起来透明。
1.4. 不绘制焦点
1.5. 鼠标经过时的图标
1.6. 选中时的图标
1.7. 禁用时显示的图标
1.8. 可能需要按钮半透明效果
作者:: 老哇的爪子 Attilax 艾龙, EMAIL:1466519819@qq.com
转载请注明来源: http://blog.csdn.net/attilax
2. 图片按钮的实现
2.1. 优先模式:button控件模式+backgroud属性
Java的实现,可以使用button模式
2.2. 其次模式2::lable/img控件实现
3. 非规则按钮的实现
3.1. 穿透颜色属性(推荐,方便)
图片中的这个颜色将不渲染。。当然复杂图片不适应
C# 支持这个实现
3.2. 透明填空:png图片模式
java的是png+prop
3.3. setMask模式
C++ qt 可以使用pn、gif图片进行setMask模式. ui->pushButton->setMask(pixmap.mask());
3.4. 重绘button的paint事件(最不推荐,复杂)
但是这个是最终实现,底层。。通用。
3.5. Html热点 map模式
4. 鼠标越过动态图片切换实现
4.1. 优先模式::css模式...
C++ qt可以使用这个模式
4.2. 其次模式2:: 设置属性模式..
Java 不支持css模式,可以使用属性模式。但是设置的属性比较多,可以抽出一个扩展类。。
4.3. 最后的模式3::写鼠标监听器
5. 半透明按钮的实现
5.1. 属性法,方便。推荐
C++ qt setAttribute(Qt::WA_TranslucentBackground, true);
5.2. 透明图片背景 法
5.3. 控件的背景动态座标法
没这个功能。。。只能把控件的背景根
据插件的坐标,设置得和窗口的背景一样
就是如果控件在x1,y1这个点上,则在控件设置背景的时候,把使用到的那张背景图在控件的现实位置也设置为x1,y1的坐标
所谓控件透明,是指控件的背景与窗口的大背景是一样的。
如果控件不移动,则可以取窗口相应位置的背景图来做控件的背景,用 setBackgroudPixmap
如果控件可移动,那就要在移动的时候再重新取窗口相应位置的背景来重新设置控件背景。
原理如此,可以自己实现的
5.4. 动态重绘(麻烦
6. Java详细按钮属性
JButton 实现了普通的三态外加选中、禁用状态,有很多方法可以设置,不要自己去写鼠标监听器。有了这些方法根本不需要自己画按钮或者用鼠标监听器。
setBorderPainted(boolean b) //是否画边框,如果用自定义图片做按钮背景可以设为 false。 setContentAreaFilled(boolean b) //是否填充,如果你的自定义图片不是矩形或存在空白边距,可以设为 false 使按钮看起来透明。 setFocusPainted(boolean b) //是否绘制焦点(例如浅色虚线框或者加粗的边框表明按钮当前有焦点)。
setMargin(Insets m) //改变边距,如果 borderPainted 和 contentAreaFilled 都设成了 false,建议把边距都调为 0:new Insets(0, 0, 0, 0)。 setIcon(Icon defaultIcon) //注意了这是改的默认图标。三态中的默认,即鼠标未在其上的时候。 setPressedIcon(Icon pressedIcon) //按下时的图标。 setRolloverIcon(Icon rolloverIcon) //鼠标经过时的图标。 setRolloverSelectedIcon(Icon rolloverSelectedIcon)
//鼠标经过时且被选中状态的图标。 setSelectedIcon(Icon selectedIcon) //选中时的图标。 setDisabledIcon(Icon disabledIcon) //禁用时显示的图标。例如可以换一张灰度图片。 setDisabledSelectedIcon(Icon disabledSelectedIcon) //禁用且被选中状态的图标。 --------------------------------------------按钮多大,去掉边距以后图片就是多大。会自动缩放的。因此如果 margin 都设成 0 的话,按钮多大图片就是多大。有了这些方法根本不需要自己画按钮或者用鼠标监听器。
7. 参考
paip.提升用户体验---c++ QPushButton按钮控件透明以及不规则按钮以及 鼠标越过动态设置 - attilax的专栏 - 博客频道 - CSDN.NET.htm
paip.提升用户体验---控件透明的设置 - attilax的专栏 - 博客频道 - CSDN.NET.htm
atitit.GUI图片非规则按钮跟动态图片切换的实现模式总结java .net c# c++ web html js的更多相关文章
- SpringMVC内容略多 有用 熟悉基于JSP和Servlet的Java Web开发,对Servlet和JSP的工作原理和生命周期有深入了解,熟练的使用JSTL和EL编写无脚本动态页面,有使用监听器、过滤器等Web组件以及MVC架构模式进行Java Web项目开发的经验。
熟悉基于JSP和Servlet的Java Web开发,对Servlet和JSP的工作原理和生命周期有深入了解,熟练的使用JSTL和EL编写无脚本动态页面,有使用监听器.过滤器等Web组件以及MVC架构 ...
- Atitit.Gui按钮与面板---项目规模的评估----文件数统计,结构,代码行数,每类型文件行数.
Atitit.Gui按钮与面板---项目规模的评估----文件数统计,结构,代码行数,每类型文件行数. 1. Kpi::: 代码行数(注释行数,空白的行数), 方法数,class数 1 2. 过滤器 ...
- Css 单图片按钮实例(css 图片变换)
1.场景描述,根据鼠标的移动,动态的切换按钮图片. 2.方法1,准备两张120*41的图片,一张正常状态图片,一张按下效果图片.在鼠标放在的按钮上设置按下图片,移开又恢复到正常状态图片.缺点:在网页上 ...
- winfrom播放动态图片
winfrom是不能直接加载的动态图片的.只能够自己写方法实现. 具体代码如下: using System; using System.Collections.Generic; using Syste ...
- devexpress表格控件gridcontrol图片列,按钮列,时间列等特殊列的实现
1.项目中经常会在表格中插入按钮列,图片列,表格列一些非文本的特殊列.如何在devexpress表格控件gridcontrol中实现呢?以下列举一个实现添加图片列,按钮列,时间列,按钮列,开关列的示例 ...
- Atitit gui控件定位解决方案
Atitit gui控件定位解决方案 1.1. 但是AUTOIT没有找图功能..可以请大侠们写一份这个UDF出来吗?1 1.2. ahk1 1.3. Java +opencv 模板匹配2 1.1. 但 ...
- Atitit. Gui控件and面板----程序快速启动区--最佳实践Launchy ObjectDock-o0g
Atitit. Gui控件and面板----程序快速启动区--最佳实践Launchy ObjectDock-o0g 两个方式::: 键盘式::先用热键呼叫出QS,然后开始输入程序中的部分字母,按En ...
- Android—基于GifView显示gif动态图片
android中显示gif动态图片用到了开源框架GifView 1.拷GifView.jar到自己的项目中. 2.将自己的gif图片拷贝到drawable文件夹 3.在xml文件中设置基本属性: &l ...
- Atitit.gui api自动化调用技术原理与实践
Atitit.gui api自动化调用技术原理与实践 gui接口实现分类(h5,win gui, paint opengl,,swing,,.net winform,)1 Solu cate1 Sol ...
随机推荐
- Java 3D游戏引擎——JME(java Monkey Engine)
转自:http://bbs.gameres.com/forum.php?mod=viewthread&tid=180732 JME(java Monkey Engine),一个非常棒的Java ...
- vim多行注释与取消
神操作 在vim中编写代码,常常会遇到多行注释和取消注释的情况,在VS中我们可以用默认的快捷键或者在设置中自定义快捷键来解决这个问题. vim既然这么强大,必然也是有快捷键来完成的.下面给出具体步骤: ...
- TZOJ 1072: 编辑距离(动态规划)
1072: 编辑距离 时间限制(普通/Java):1000MS/10000MS 内存限制:65536KByte 总提交: 917 測试通过:275 描写叙述 如果字符串的 ...
- 多个Mapper和Reducer的Job
多个Mapper和Reducer的Job @(Hadoop) 对于复杂的mr任务来说,只有一个map和reduce往往是不能够满足任务需求的,有可能是需要n个map之后进行reduce,reduce之 ...
- [译]使用scikit-learn进行机器学习的简介(教程1)
原文:http://www.cnblogs.com/taceywong/p/4568806.html 原文地址:http://scikit-learn.org/stable/tutorial/basi ...
- redis在linux下安装并測试(在spring下调用)
官网帮助文档例如以下 Installation Download, extract and compile Redis with: $ wget http://download.redis.io/re ...
- gedit如何使用代码片段
gedit的片段插件 1 打开这个插件 2 以HTML为例,我们看到触发器是doctype 3则我在编辑一个HTML文档的时候,先输入doctype,再按Tab键,将会自动提示,我选择即可插入 ...
- vscode - 移动端适配(cssrem)
建议使用Chrome浏览器. 1.第一步,安装扩展以及配置 2.第二步,使用(记得按一下↓)
- JQuery 之CSS操作
JQuery 之CSS操作 设置 <p> 元素的颜色: 将所有段落的颜色设为红色 $(".btn1").click(function(){ $("p" ...
- webpack css打包为一个css
1.安装 npm install extract-text-webpack-plugin --save-dev 2.项目目录: index文件夹下的index.css: body{ backgroun ...