圆角与正圆形的Button

本文介绍如何在Android应用中创建自定义圆角按钮。通过在res/drawable-mdpi目录下建立shape.xml文件并设置相应的属性,如按钮的形状、颜色、弧度等,可以轻松实现美观的圆角按钮效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在res目录下的drawable-mdpi建立xml文件shape.xml。如下图所示:


shape.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <shape
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:shape="rectangle">
        <!-- 填充的颜色 -->
        <solid android:color="#FFFFFF" />
        <!-- 设置按钮的四个角为弧形 -->
        <!-- android:radius 弧形的半径 -->
        <corners android:radius="5dip" />
       
    <!-- padding:Button里面的文字与Button边界的间隔 -->
    <padding
       android:left="10dp"
       android:top="10dp"
       android:right="10dp"
       android:bottom="10dp"
    />
    </shape>

android:shape="oval"即为正圆形,<corners android:radius="10dip" />对于shape="oval"没有任何作用。

main.xml
在android:background="@drawable/shape"就使用了shape.xml资源。

<pre name="code" class="html"><?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
<TextView  
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="@string/hello"
    />
<Button
        android:id="@+id/roundButton"
        android:text=" 圆角按钮 "
        android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:background="@drawable/shape"
        />
</LinearLayout>


 

strings.xml
    <?xml version="1.0" encoding="utf-8"?>
    <resources>
        <string name="hello">Hello World, RoundButtonDemoActivity!</string>
        <string name="app_name">RoundButtonDemo</string>
    </resources>





RoundButtonDemoActivity.java

    package com.android.RoundButtonDemo.activity;
    import android.app.Activity;
    import android.os.Bundle;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.Button;
    import android.widget.Toast;
    public class RoundButtonDemoActivity extends Activity {
        Button roundButton;
        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.main);
            
            roundButton=(Button)findViewById(R.id.roundButton);
          //使用匿名类注册Button事件
            roundButton.setOnClickListener(new OnClickListener()
          {               
                            public void onClick(View v)
                            {
                                    Toast.makeText(RoundButtonDemoActivity.this, "你点击了圆角按钮",Toast.LENGTH_LONG).show();
                            }
                    });
        }
    }


效果图:


PS:我正在参加IT博客大赛,欢迎大家来投我一票的。
http://blog.51cto.com/contest2011/3061169

源代码下载:

RoundButtonDemo.rar(41.38 KB, 下载次数: 201)




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值