圆角按钮

无需图片,使用 CSS3 实现圆角按钮

HTML 代码就这么简单:

<a href="#" class="button green">button</a>

<a href="#" class="button blue">button</a>
<a href="#" class="button gray">button</a>

如果没有 CSS ,那么上面的 HTML 执行起来是这样的:

无需图片,使用 CSS3 实现圆角按钮

开始 CSS3 的编写:

.button {
	display: inline-block;
	position: relative;
	margin: 10px;
	padding: 0 20px;
	text-align: center;
	text-decoration: none;
	font: bold 12px/25px Arial, sans-serif;
}

一些不同颜色的按钮样式:

.green {
	color: #3e5706;
	background: #a5cd4e;
}

/* Blue Color */

.blue {
	color: #19667d;
	background: #70c9e3;
}

/* Gray Color */

.gray {
	color: #515151;
	background: #d3d3d3;
}

到这一步后按钮看起来是这样的:

无需图片,使用 CSS3 实现圆角按钮

接下来开始用 CSS 处理圆角:

.button {
	display: inline-block;
	position: relative;
	margin: 10px;
	padding: 0 20px;
	text-align: center;
	text-decoration: none;
	font: bold 12px/25px Arial, sans-serif;

	text-shadow: 1px 1px 1px rgba(255,255,255, .22);

	-webkit-border-radius: 30px;
	-moz-border-radius: 30px;
	border-radius: 30px;

	-webkit-box-shadow: 1px 1px 1px rgba(0,0,0, .29), inset 1px 1px 1px rgba(255,255,255, .44);
	-moz-box-shadow: 1px 1px 1px rgba(0,0,0, .29), inset 1px 1px 1px rgba(255,255,255, .44);
	box-shadow: 1px 1px 1px rgba(0,0,0, .29), inset 1px 1px 1px rgba(255,255,255, .44);

	-webkit-transition: all 0.15s ease;
	-moz-transition: all 0.15s ease;
	-o-transition: all 0.15s ease;
	-ms-transition: all 0.15s ease;
	transition: all 0.15s ease;
}

现在的按钮圆润多了,看看:

无需图片,使用 CSS3 实现圆角按钮

还不够啊,没有立体效果,再完善完善:

/* Green Color */

.green {
	color: #3e5706;

	background: #a5cd4e; /* Old browsers */
	background: -moz-linear-gradient(top,  #a5cd4e 0%, #6b8f1a 100%); /* FF3.6+ */
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#a5cd4e), color-stop(100%,#6b8f1a)); /* Chrome,Safari4+ */
	background: -webkit-linear-gradient(top,  #a5cd4e 0%,#6b8f1a 100%); /* Chrome10+,Safari5.1+ */
	background: -o-linear-gradient(top,  #a5cd4e 0%,#6b8f1a 100%); /* Opera 11.10+ */
	background: -ms-linear-gradient(top,  #a5cd4e 0%,#6b8f1a 100%); /* IE10+ */
	background: linear-gradient(top,  #a5cd4e 0%,#6b8f1a 100%); /* W3C */
}

/* Blue Color */

.blue {
	color: #19667d;

	background: #70c9e3; /* Old browsers */
	background: -moz-linear-gradient(top,  #70c9e3 0%, #39a0be 100%); /* FF3.6+ */
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#70c9e3), color-stop(100%,#39a0be)); /* Chrome,Safari4+ */
	background: -webkit-linear-gradient(top,  #70c9e3 0%,#39a0be 100%); /* Chrome10+,Safari5.1+ */
	background: -o-linear-gradient(top,  #70c9e3 0%,#39a0be 100%); /* Opera 11.10+ */
	background: -ms-linear-gradient(top,  #70c9e3 0%,#39a0be 100%); /* IE10+ */
	background: linear-gradient(top,  #70c9e3 0%,#39a0be 100%); /* W3C */
}

/* Gray Color */

.gray {
	color: #515151;

	background: #d3d3d3; /* Old browsers */
	background: -moz-linear-gradient(top,  #d3d3d3 0%, #8a8a8a 100%); /* FF3.6+ */
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#d3d3d3), color-stop(100%,#8a8a8a)); /* Chrome,Safari4+ */
	background: -webkit-linear-gradient(top,  #d3d3d3 0%,#8a8a8a 100%); /* Chrome10+,Safari5.1+ */
	background: -o-linear-gradient(top,  #d3d3d3 0%,#8a8a8a 100%); /* Opera 11.10+ */
	background: -ms-linear-gradient(top,  #d3d3d3 0%,#8a8a8a 100%); /* IE10+ */
	background: linear-gradient(top,  #d3d3d3 0%,#8a8a8a 100%); /* W3C */
}

现在爽了,漂亮了,你喜欢这样的按钮吗?

无需图片,使用 CSS3 实现圆角按钮

为了让按钮更大一点,我们增加了个 big 样式:

<a href="#" class="button big green">sign in <span>One minute</span></a>
<a href="#" class="button big blue">sign in <span>One minute</span></a>

<a href="#" class="button big gray">sign in <span>One minute</span></a>

/* Big Button Style */

.big {
	padding: 0 40px;
	padding-top: 10px;
	height: 45px;
	text-transform: uppercase;
	font: bold 20px/22px Arial, sans-serif;
}

.big span {
	display: block;
	text-transform: none;
	font: italic normal 12px/18px Georgia, sans-serif;
	text-shadow: 1px 1px 1px rgba(255,255,255, .12);
}

大按钮的效果:

无需图片,使用 CSS3 实现圆角按钮

我们还需要处理下当鼠标移到按钮上方时显示不同的效果:

.button:hover {
	-webkit-box-shadow: 1px 1px 1px rgba(0,0,0,.29), inset 0px 0px 2px rgba(0,0,0, .5);
	-moz-box-shadow: 1px 1px 1px rgba(0,0,0,.29), inset 0px 0px 2px rgba(0,0,0, .5);
	box-shadow: 1px 1px 1px rgba(0,0,0,.29), inset 0px 0px 2px rgba(0,0,0, .5);
}
.button:active {
	-webkit-box-shadow: inset 0px 0px 3px rgba(0,0,0, .8);
	-moz-box-shadow: inset 0px 0px 3px rgba(0,0,0, .8);
	box-shadow: inset 0px 0px 3px rgba(0,0,0, .8);
}

效果如下:

无需图片,使用 CSS3 实现圆角按钮

好了,完美的CSS3按钮解决方案。

### 回答1: 在WinForm中实现圆角按钮有多种方法,下面我将介绍其中一种常见的方法。 首先,我们需要在项目中引用`System.Drawing`和`System.Windows.Forms`命名空间。然后创建一个自定义的`RoundButton`类,继承自`Button`类。 在`RoundButton`类中,我们需要重写`OnPaint`方法来绘制圆角按钮。在重写的`OnPaint`方法中,首先创建一个`Graphics`对象,然后使用`SmoothingMode`属性来设置`Graphics`对象的平滑模式为`AntiAlias`,以实现圆角效果。 然后,我们可以使用`Graphics`对象的各种方法来绘制圆角按钮的外观,比如使用`FillPath`方法来填充按钮的背景色,使用`DrawString`方法来绘制按钮上的文本等。可以根据需求自定义绘制的外观。 接下来,我们需要在`RoundButton`类中添加一些属性,来控制圆角按钮的外观。比如添加一个`CornerRadius`属性来设置按钮圆角半径,添加一个`ButtonColor`属性来设置按钮的背景色等。 最后,在`Form`类中使用`RoundButton`类创建圆角按钮的实例,并设置相关属性即可。比如可以使用`button1.CornerRadius = 10;`来设置按钮圆角半径为10,使用`button1.ButtonColor = Color.Blue;`来设置按钮的背景色为蓝色等。 通过以上步骤,我们就可以在WinForm中实现圆角按钮了。当然,上述只是其中一种实现方式,实际上还有其他的方法,可以根据自己的需求来选择合适的方法。 ### 回答2: WinForms是微软开发的一种用于创建Windows桌面应用程序的框架,它可以让开发人员使用C#或其他.NET语言开发强大的Windows应用。在WinForms中,要实现圆角按钮,可以使用以下方法: 1. 继承Button类:创建一个自定义的圆角按钮类,继承自Button类。在自定义的按钮类中,可以重写OnPaint方法来绘制按钮的外观。使用System.Drawing命名空间中的Graphics对象和相关的绘制方法可以实现绘制圆角。 2. 自定义绘制控件:在使用Button控件时,可以使用自定义的绘制事件来改变按钮的外观。在按钮的Paint事件中,可以使用System.Drawing命名空间中的相关方法绘制圆角。 无论是哪种方法,一般的步骤如下: 1. 创建一个可以处理圆角的控件类或事件处理程序。 2. 在该类中重写OnPaint方法或处理相应的绘制事件。 3. 在绘制方法中,使用Graphics对象的相关方法来绘制圆角。 4. 根据需要设置按钮的颜色、边框、填充等属性。 5. 在应用程序中使用自定义的圆角按钮控件。 需要注意的是,绘制圆角按钮可能需要管理按钮的状态,例如获取焦点、鼠标悬浮等。可以在相应的事件中处理这些状态,并更新相应的绘制。 总结来说,要实现WinForms中的圆角按钮,可以通过继承Button类或自定义绘制事件来实现。在绘制方法中,使用Graphics对象的方法绘制圆角,并根据需要设置按钮的属性。 ### 回答3: WinForm是一个用于创建Windows桌面应用程序的开发工具。要创建一个圆角按钮,可以使用WinFormButton控件,并结合一些绘图技术来实现。 首先,在WinForm窗体中添加一个Button控件。然后,在按钮的属性中将FlatStyle属性设置为Flat,并设置BackColor属性为透明,以便实现圆角的效果。 接下来,可以通过重写Button控件的OnPaint方法来绘制圆角按钮。在OnPaint方法中,可以使用System.Drawing命名空间中的一些绘图类来实现圆角边框以及背景的绘制。 首先,使用GraphicsPath类创建一个路径对象,并使用AddEllipse方法在按钮的边界上创建一个圆形路径。然后,使用Graphics对象的DrawPath方法将圆角路径绘制在按钮的背景上。 接着,可以使用Drawing2D命名空间中的GraphicsPath类的AddArc方法来创建圆角的边框路径。通过设置路径的起始角度和长度,可以调整圆角的大小。然后,使用Graphics对象的DrawPath方法将圆角边框绘制在按钮上。 最后,可以通过设置按钮控件的Region属性为生成的圆角路径,来将按钮的点击区域限制在圆角范围内。这样,当用户点击按钮时,只有在圆角区域内的点击事件才会触发。 以上就是一个简单的实现WinForm圆角按钮的方法。通过结合Button控件和绘图技术,可以轻松实现圆角按钮的效果。但需要注意的是,在实际应用中,可能还需要处理按钮的鼠标交互效果和文字显示等其他方面的细节。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值