zoukankan      html  css  js  c++  java
  • 【传】玩转Android---UI篇---ImageButton(带图标的按钮)

    原文网址:http://hualang.iteye.com/blog/964049

    除了Android系统自带的Button按钮一万,还提供了带图标的按钮ImageButton

    要制作带图标的按钮,首先要在布局文件中定义ImageButton,然后通过setImageDrawable方法来设置要显示的图标。

    注意:

    我们可以在布局文件中就直接设置按钮的图标,如

    android:src="@drawable/icon1"

    我们也可以在程序中设置自定义图标

    imgbtn3.setImageDrawable(getResources().getDrawable(R.drawable.icon2));

    我们还可以使用系统自带的图标

    imgbtn4.setImageDrawable(getResources().getDrawable(android.R.drawable.sym_call_incoming));

    设置完按钮的图标后,需要为按钮设置监听setOnClickListener,以此捕获事件并处理

    下面的例子讲述的是由4个图标按钮组成的布局,其中三个按钮的图标是自定义的,第四个按钮的图标是系统的,当点击按钮1的时候,弹出dialog,当点击按钮2的时候,点击确定后,可以将按钮2的图标变成按钮3的图标,当点击按钮3的时候,按钮3的图标变成了系统打电话的图标,点击按钮4,显示一个提示dialog

    ImageButtonTest.java源代码

    Java代码  收藏代码
    1. package org.loulijun.imagebutton;  
    2.   
    3. import android.app.Activity;  
    4. import android.app.AlertDialog;  
    5. import android.app.Dialog;  
    6. import android.content.DialogInterface;  
    7. import android.os.Bundle;  
    8. import android.view.View;  
    9. import android.widget.Button;  
    10. import android.widget.ImageButton;  
    11. import android.widget.TextView;  
    12.   
    13. public class ImageButtonTest extends Activity {  
    14.     /** Called when the activity is first created. */  
    15.     TextView textview;  
    16.     ImageButton imgbtn1;  
    17.     ImageButton imgbtn2;  
    18.     ImageButton imgbtn3;  
    19.     ImageButton imgbtn4;  
    20.     @Override  
    21.     public void onCreate(Bundle savedInstanceState) {  
    22.         super.onCreate(savedInstanceState);  
    23.         setContentView(R.layout.main);  
    24.           
    25.         textview=(TextView)findViewById(R.id.textview);  
    26.         //分别取得4个ImageButton对象  
    27.         imgbtn1=(ImageButton)findViewById(R.id.imagebutton1);  
    28.         imgbtn2=(ImageButton)findViewById(R.id.imagebutton2);  
    29.         imgbtn3=(ImageButton)findViewById(R.id.imagebutton3);  
    30.         imgbtn4=(ImageButton)findViewById(R.id.imagebutton4);  
    31.           
    32.         //分别为ImageButton设置图标  
    33.         //imgbtn1已经在main.xml布局中设置了图标,所以就不在这里设置了(设置图标即可在程序中设置,也可在布局文件中设置)  
    34.         imgbtn2.setImageDrawable(getResources().getDrawable(R.drawable.icon));//在程序中设置图标  
    35.         imgbtn3.setImageDrawable(getResources().getDrawable(R.drawable.icon2));  
    36.         imgbtn4.setImageDrawable(getResources().getDrawable(android.R.drawable.sym_call_incoming));//设置系统图标  
    37.           
    38.         //下面为各个按钮设置事件监听  
    39.         imgbtn1.setOnClickListener(new Button.OnClickListener()  
    40.         {  
    41.             @Override  
    42.             public void onClick(View v) {  
    43.                 // TODO Auto-generated method stub  
    44.                 Dialog dialog=new AlertDialog.Builder(ImageButtonTest.this)  
    45.                 .setTitle("提示")  
    46.                 .setMessage("我是ImageButton1")  
    47.                 .setPositiveButton("确定",new DialogInterface.OnClickListener() {  
    48.                       
    49.                     @Override  
    50.                     public void onClick(DialogInterface dialog, int which) {  
    51.                         // TODO Auto-generated method stub  
    52.                         //相应的处理操作  
    53.                     }  
    54.                 }).create();  
    55.                 dialog.show();  
    56.             }  
    57.               
    58.         });  
    59.           
    60.         imgbtn2.setOnClickListener(new Button.OnClickListener()  
    61.         {  
    62.             @Override  
    63.             public void onClick(View v) {  
    64.                 // TODO Auto-generated method stub  
    65.                 Dialog dialog=new AlertDialog.Builder(ImageButtonTest.this)  
    66.                 .setTitle("提示")  
    67.                 .setMessage("我是ImageButton2,我要使用ImageButton3的图标")  
    68.                 .setPositiveButton("确定",new DialogInterface.OnClickListener() {  
    69.                       
    70.                     @Override  
    71.                     public void onClick(DialogInterface dialog, int which) {  
    72.                         // TODO Auto-generated method stub  
    73.                         imgbtn2.setImageDrawable(getResources().getDrawable(R.drawable.icon2));  
    74.                     }  
    75.                 }).create();  
    76.                 dialog.show();  
    77.             }  
    78.               
    79.         });  
    80.           
    81.         imgbtn3.setOnClickListener(new Button.OnClickListener()  
    82.         {  
    83.             @Override  
    84.             public void onClick(View v) {  
    85.                 // TODO Auto-generated method stub  
    86.                 Dialog dialog=new AlertDialog.Builder(ImageButtonTest.this)  
    87.                 .setTitle("提示")  
    88.                 .setMessage("我是ImageButton3,我想使用系统打电话的图标")  
    89.                 .setPositiveButton("确定",new DialogInterface.OnClickListener() {  
    90.                       
    91.                     @Override  
    92.                     public void onClick(DialogInterface dialog, int which) {  
    93.                         // TODO Auto-generated method stub  
    94.                         imgbtn3.setImageDrawable(getResources().getDrawable(android.R.drawable.sym_action_call));  
    95.                     }  
    96.                 }).create();  
    97.                 dialog.show();  
    98.             }  
    99.               
    100.         });  
    101.           
    102.         imgbtn4.setOnClickListener(new Button.OnClickListener()  
    103.         {  
    104.             @Override  
    105.             public void onClick(View v) {  
    106.                 // TODO Auto-generated method stub  
    107.                 Dialog dialog=new AlertDialog.Builder(ImageButtonTest.this)  
    108.                 .setTitle("提示")  
    109.                 .setMessage("我是使用的系统图标")  
    110.                 .setPositiveButton("确定",new DialogInterface.OnClickListener() {  
    111.                       
    112.                     @Override  
    113.                     public void onClick(DialogInterface dialog, int which) {  
    114.                         // TODO Auto-generated method stub  
    115.                         //相应的处理操作  
    116.                     }  
    117.                 }).create();  
    118.                 dialog.show();  
    119.             }  
    120.               
    121.         });  
    122.     }  
    123. }  

     布局文件main.xml

    Java代码  收藏代码
    1. <?xml version="1.0" encoding="utf-8"?>  
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    3.     android:orientation="vertical"  
    4.     android:layout_width="fill_parent"  
    5.     android:layout_height="fill_parent"  
    6.     >  
    7. <TextView    
    8.     android:id="@+id/textview"  
    9.     android:layout_width="fill_parent"   
    10.     android:layout_height="wrap_content"   
    11.     android:text="ImageButton测试案例"  
    12.     />  
    13. <ImageButton  
    14.     android:id="@+id/imagebutton1"  
    15.     android:layout_width="wrap_content"  
    16.     android:layout_height="wrap_content"  
    17.     android:src="@drawable/icon1"  
    18. />  
    19. <ImageButton  
    20.     android:id="@+id/imagebutton2"  
    21.     android:layout_width="wrap_content"  
    22.     android:layout_height="wrap_content"  
    23. />  
    24. <ImageButton  
    25.     android:id="@+id/imagebutton3"  
    26.     android:layout_width="wrap_content"  
    27.     android:layout_height="wrap_content"  
    28. />  
    29. <ImageButton  
    30.     android:id="@+id/imagebutton4"  
    31.     android:layout_width="wrap_content"  
    32.     android:layout_height="wrap_content"  
    33. />  
    34. </LinearLayout>  

     运行效果如下:



     点击第一个按钮后



     点击确定后,点击第二个按钮



     点击确定,此时会看到按钮二的图标编程和按钮三的图标一样了



     点击按钮三



     点击确定后,发现按钮三的图标变成了系统打电话的图标



     点击按钮四


  • 相关阅读:
    POJ3233]Matrix Power Series && [HDU1588]Gauss Fibonacci
    [codeforces 508E]Maximum Matching
    [SDOI2011]染色
    [CSU1806]Toll
    [HDU4969]Just a Joke
    [HDU1071]The area
    [HDU1724]Ellipse
    [VIJOS1889]天真的因数分解
    [BZOJ3379] Turning in Homework
    [BZOJ1572] WorkScheduling
  • 原文地址:https://www.cnblogs.com/wi100sh/p/4363242.html
Copyright © 2011-2022 走看看