android自定义view(一)

第一种方式


1  先创建这样一个自定义控件

public class CustomView extends View {
Paint paint;
public CustomView(Context context) {
super(context);
init(context,null);
}
public CustomView(Context context, AttributeSet attrs) {
super(context, attrs);
System.out.println("两个参数的构造函数");
init(context,attrs);
}
public CustomView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
init(context,attrs);
}
private void init(Context context, AttributeSet attrs) {
paint = new Paint();
paint.setColor(Color.RED);
paint.setTextSize(25.0f);

}
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);

canvas.drawText("一个view里面画出来的一句话", 11, 111, paint);
}


@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
}


}


2 在布局中取加载它

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:Android="http://schemas.android.com/apk/res/android"
    xmlns:dl="http://schemas.android.com/apk/res/cn.itheima.customview"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >
    
    <!-- dl中可用的属性为在attr.xml中定义的属性 -->
    <cn.itheima.customview.CustomView  //  这个就是一个类似button的控件了
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        dl:textColor="#ff00ff00"
        dl:textSize="25dip" >
    </cn.itheima.customview.CustomView>

</LinearLayout>


3  加载这个布局就好了 

//布局文件中使用了自定义控件
public class CustomViewActivity extends Activity {
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
    }
}


第二种方式

1 线创建个View类

public class MainView extends FrameLayout implements View.OnClickListener{
  private Context mContext;  
      
   private Activity mActivity;  
   private Button mArgButton;  
   private Button mGlobleButton;  
   private Button mExitButton;  
     
   public MainView(Context context){  
       super(context);// ?????????  这句话的作用
       setupViews();  
   }  
 
   public MainView(Context context, AttributeSet attrs) {  
       super(context, attrs);  
       setupViews();  
   }  
     
     
   private void setupViews(){  
       //获取View的上下文.  
       mContext = getContext(); 
       //1   利用了多态的特性
       //这里将Context转换为Activity. 。 
       mActivity = (Activity)mContext; 
       
       // 2  动态添加布局文件
       LayoutInflater inflater = LayoutInflater.from(mContext);  
       View v = inflater.inflate(R.layout.activity_main, null);  
       addView(v)
;   // add View()
       
       // 3   多个button监听一个事件
       mArgButton = (Button)v.findViewById(R.id.arg_button);  
       mGlobleButton = (Button)v.findViewById(R.id.glo_button);  
       mExitButton = (Button)v.findViewById(R.id.exit_button);  
         
       mArgButton.setOnClickListener(this);  
       mGlobleButton.setOnClickListener(this);  
       mExitButton.setOnClickListener(this);  
   }  
 
   public void onClick(View v) {  
       if(v == mArgButton){  
           ToolUtils.showToast(mContext, "我是通过传递Context参数显示的!");  
       }else if(v == mGlobleButton){  
           ToolUtils.showToast("我是通过全局Context显示的!");  
       }else{  
           mActivity.finish();  
       }  
   }  
}


2  在activity中加载这个View

public class ApplicationDemoActivity extends Activity {  
    @Override  
    public void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
         // 1 创建自定义的视图  传递上下文。2 在构造函数中调用设置视图的方法
        MainView mMainView = new MainView(this);  
        setContentView(mMainView);  
    }  
      

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
大家好,今天给大家分享一下Android里的Context的一些用法. 这里大致可以分为两种:一是传递Context参数,二是调用全局的Context. 其实我们应用启动的时候会启动Application这个类,这个类是在AndroidManifest.xml文件里其实是默认的 为了让大家更容易理解,写了一个简单的Demo.步骤如下: 第1步:新建一个Android工程ApplicationDemo,目录结构如下: 第2步:新建一个工具类ToolsUtil.java,代码如下 package com.tutor.application; import android.content.Context; import android.widget.Toast; /** * @author carlshen. * 应用的一些工具类. */ public class ToolUtils { /** * 参数带Context. * @param context * @param msg */ public static void showToast(Context context,String msg){ Toast.makeText(context, msg, Toast.LENGTH_SHORT).show(); } /** * 调用全局的Context. * @param msg */ public static void showToast(String msg){ Toast.makeText(MainApplication.getContext(), msg, Toast.LENGTH_SHORT).show(); } } 第3步:新建一个View命名为MainView.java就是我们Activity现实的View.代码如下: package com.tutor.application; import android.app.Activity; import android.content.Context; import android.util.AttributeSet; import android.view.LayoutInflater; import android.view.View; import android.widget.Button; import android.widget.FrameLayout; /** * @author carlshen. * 自定义的MainView. */ public class MainView extends FrameLayout implements View.OnClickListener{ private Context mContext; private Activity mActivity; /** * 参数Button. */ private Button mArgButton; /** * 全局Button. */ private Button mGlobleButton; /** * 退出Button. */ private Button mExitButton; public MainView(Context context){ super(context); setupViews(); } public MainView(Context context, AttributeSet attrs) { super(context, attrs); setupViews(); } private void setupViews(){ //获取View的上下文. mContext = getContext(); //这里将Context转换为Activity. mActivity = (Activity)mContext; LayoutInflater inflater = LayoutInflater.from(mContext); View v = inflater.inflate(R.layout.main, null); addView(v); mArgButton = (Button)v.findViewById(R.id.arg_button); mGlobleButton = (Button)v.findViewById(R.id.glo_button); mExitButton = (Button)v.findViewById(R.id.exit_button); mArgButton.setOnClickListener(this); mGlobleButton.setOnClickListener(this); mExitButton.setOnClickListener(this); } public void onClick(View v) { if(v == mArgButton){ ToolUtils.showToast(mContext, "我是通过传递Context参数显示的!"); }else if(v == mGlobleButton){ ToolUtils.showToast("我是通过全局Context显示的!"); }else{ mActivity.finish(); } } } 这里MainView.java使用的布局main.xml代码如下: <?xml version="1.0" encoding="utf-8"?> 第4步:修改ApplicationDemoActivity.java,代码如下: package com.tutor.application; import android.app.Activity; import android.os.Bundle; public class ApplicationDemoActivity extends Activity { private static Context aContext; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); MainView mMainView = new MainView(this); setContentView(mMainView); aContext = getApplicationContext(); } /**获取Context. * @return */ public static Context getContext(){ return aContext; } } 第5步:运行上述工程效果如下:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值