0824Android基础CheckBox+ImageView+ListView

CheckBox

  常用的用法有text,button(设置点击按键的style),background等,和RadioButton的区别是这家伙可以同时选中好几个,而RadioButton值能够选择一组中的一个(比如常见的选择性别的页面,除了选男就是选女,不能一起选的。。。要不然成了不男不女了╮(╯▽╰)╭)
  

  • 一个用于设置控件中字体的大小的tip: android:textAppearance=”@android:style/TextAppearance.Large”
    可以选择Large、Medium、Small

这个控件比较简单,直接上布局。包括一个设置密码是否可见的部分,注意这家伙设置点击事件的时候用的是setOnCheckedChangeListener。

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin">

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="爱好"
        android:textAppearance="@android:style/TextAppearance.Large" />

    <CheckBox
        android:id="@+id/checkbox_basketball"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="篮球" />

    <CheckBox
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="游戏" />

    <CheckBox
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="睡觉" />

    <CheckBox
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="电影" />

    <Button
        android:id="@+id/btn_commit"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="提交信息" />

    <EditText
        android:id="@+id/edittext_password"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="输入密码"
        android:password="true" />

    <CheckBox
        android:id="@+id/checkbox_showpassword"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="right"
        android:text="显示密码" />
</LinearLayout>

//相应的Activity中的点击事件
checkbox_showpassword.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
            @Override
            public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
                if(isChecked){
                    edittext_password.setTransformationMethod(null);
                }else{
                    edittext_password.setTransformationMethod(new PasswordTransformationMethod());
                }
            }
        });

这里写图片描述

ImageView

常用的属性
- src,默认不会被拉伸
- background,默认图片会被拉伸
- scaleType+位置(用来调整的,必须要有需要调整的东西)
- tint蒙板覆盖
  又是一串代码,大体上src的属性的具体功能,另外在Activity上继承了监听器的接口,然后平常写点击事件的方法有点不一样。布局的时候涉及到了ScrollView,老师只提到它下面只能有一个子标签。。。(⊙o⊙)…用的明星的照片做的Demo,不会涉嫌侵权吧应该=。=

<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.example.laowang.android0824.ImageViewActivity">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical">

        <ImageView
            android:id="@+id/imageview_example"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="@mipmap/kobe" />
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:gravity="center_horizontal">
            <Button
                android:id="@+id/btn_addAlpha"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="增加透明度"/>
            <Button
                android:id="@+id/btn_subAlpha"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="减少透明度"/>
        </LinearLayout>

        <ImageView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:src="@mipmap/anglebaby" />

        <ImageView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:scaleType="centerCrop"
            android:src="@mipmap/anglebaby"
            android:tint="@color/pink"/>

        <ImageView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:src="@mipmap/anglebaby"
            android:scaleType="center"/>

        <ImageView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:src="@mipmap/anglebaby"
            android:scaleType="fitCenter"/>

        <ImageView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:src="@mipmap/anglebaby"
            android:scaleType="fitEnd"/>

        <ImageView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:src="@mipmap/anglebaby"
            android:scaleType="fitStart"/>
        <ImageView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:src="@mipmap/anglebaby"
            android:scaleType="fitXY"/>

    </LinearLayout>

</ScrollView>



//Activity
import android.annotation.TargetApi;
import android.app.Activity;
import android.os.Build;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.ImageView;
//多次用到点击事件,干脆直接继承对应接口
public class ImageViewActivity extends Activity implements View.OnClickListener{
    private Button mbtn_addAphla;
    private Button mbtn_subAphla;
    private ImageView mimageView1;
    private int count;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_image_view);
        mimageView1 = (ImageView) findViewById(R.id.imageview_example);
        mbtn_addAphla= (Button) findViewById(R.id.btn_addAlpha);
        mbtn_subAphla= (Button) findViewById(R.id.btn_subAlpha);
//        继承接口后对应点击事件的写法
        mbtn_addAphla.setOnClickListener(this);
        mbtn_subAphla.setOnClickListener(this);
//        设置ImageView的图片
        mimageView1.setImageResource(R.mipmap.anglebaby);
    }

    @TargetApi(Build.VERSION_CODES.JELLY_BEAN)
    @Override
    public void onClick(View v) {
        int code= Build.VERSION.SDK_INT;
        switch (v.getId()){
            case R.id.btn_addAlpha:
                count+=5;
                //版本不同,用来设置透明度的方法也不同
                if(code<16){
                    mimageView1.setAlpha(count);
                }else{
                    mimageView1.setImageAlpha(count);
                }
                break;
            case R.id.btn_subAlpha:
                count-=5;
                if(code<16){
                    mimageView1.setAlpha(count);
                }else{
                    mimageView1.setImageAlpha(count);
                }
                break;
            default:
                break;
        }

    }
}

这里写图片描述
这里写图片描述

ListView

  ListView:不允许使用OnClickListener,可以用setOnItemClickListener(其中postion是指的点击中 的第position个数据)OnItemLongClickListener
  适配器(3种方式)(每种方法中的activity_list_view都一样):

ArrayAdapter只能放一个文本;

//activity_list_view
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
    android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:paddingBottom="@dimen/activity_vertical_margin"
    tools:context="com.example.laowang.android0824.MyListActivity">

    <ListView
        android:id="@+id/listView"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        ></ListView>

</LinearLayout>


//就是系统自带的xml文件,单独提出来改了个颜色而已,调用方法和系统自带的不一样
<?xml version="1.0" encoding="utf-8"?>
    <TextView xmlns:android="http://schemas.android.com/apk/res/android"
        android:id="@android:id/text1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textAppearance="?android:attr/textAppearanceListItemSmall"
        android:gravity="center_vertical"
        android:textColor="@color/pink"
        android:minHeight="?android:attr/listPreferredItemHeightSmall" />

//活动中的代码
public class MyListActivity extends Activity {
    private ListView mlistView;
    String[] array={"张三","李四","王五","赵六"};
    @Override
     protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_list_view);
        mlistView= (ListView) findViewById(R.id.listView);
        ArrayAdapter<String> adapter=new ArrayAdapter<String>(this,R.layout.simple_list,array);
        mlistView.setAdapter(adapter);
    }
}

这里写图片描述

SimpleAdapter可以放多个文本,MVC设计模式,M是数据,V是布局,C是控制;

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_margin="15dp"
    android:gravity="center_vertical"
    android:orientation="horizontal">
    <ImageView
        android:id="@+id/iv_img"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"

        />
    <TextView
        android:id="@+id/tv_name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="姓名" />

    <TextView
        android:id="@+id/tv_age"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="15dp"
        android:text="年龄" />

    <TextView
        android:id="@+id/tv_sex"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="性别" />
</LinearLayout>

这里写图片描述

import android.app.Activity;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import com.example.laowang.android0824.adapter.StudentAdapter;
import com.example.laowang.android0824.module.Student;
import java.lang.reflect.Array;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

public class MyListActivity extends Activity {
    private ListView mlistView;
    private List<HashMap<String,String>> mdata;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_list_view);
        mlistView= (ListView) findViewById(R.id.listView);
       mlistView.setAdapter(adapter);
//      初始化数据
        initData();
        //以R.layout.item_simple_adapter的方式从mdata中取出数据(按照String中的名字)依次放入布局文件中。
        SimpleAdapter adapter=new SimpleAdapter(this,mdata,R.layout.item_simple_adapter,new String[]{"name","age","sex"},new int[]{R.id.tv_name,R.id.tv_age,R.id.tv_sex});
        //ListView设置适配器
        mlistView.setAdapter(adapter);

        mlistView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
            //  position是指点击中的第position个数据
                HashMap<String,String> itemData=mdata.get(position);
                Log.d("data",""+itemData.get("name")+itemData.get("age")+itemData.get("sex"));
            }
        });


    }

    private void initData() {
        mdata=new ArrayList<>();
        HashMap<String,String> zhangsan=createHashMap("张三","22","男");
        mdata.add(zhangsan);
        HashMap<String,String> lisi=createHashMap("李四","23","男");
        mdata.add(lisi);
        HashMap<String,String> lihua=createHashMap("李华","21","女");
        mdata.add(lihua);
    }

    private HashMap<String, String> createHashMap(String name,String age,String sex) {
        HashMap<String,String> data=new HashMap<>();
        data.put("name",name);
        data.put("age",age);
        data.put("sex",sex);
        return data;
    }
}

这里写图片描述
这里写图片描述

炒鸡重要★自定义adapter:BaseApadater ListView自定义

  自定义adapter需要继承BaseAdapter。
  MVC设计模式,M数据存在Student类中,V界面还是用item_simple_adapter.xml,然后C控制写在StudentAdapter中。

//学生数据
public class Student {
    private String name;
    private String age;
    private String sex;
    private int img;
    public Student(){

    }

    /**
     *
     * @param name 学生姓名
     * @param age 学生年龄
     * @param sex 学生性别
     * @param img 学生照片
     */
    public Student(String name,String age,String sex,int img){
        this.name=name;
        this.age=age;
        this.sex=sex;
        this.img=img;
    }

    public int getImg() {
        return img;
    }

    public void setImg(int img) {
        this.img = img;
    }

    public void setName(String name) {
        this.name = name;
    }

    public void setAge(String age) {
        this.age = age;
    }

    public void setSex(String sex) {
        this.sex = sex;
    }

    public String getName() {
        return name;
    }

    public String getAge() {
        return age;
    }

    public String getSex() {
        return sex;
    }
}


//学生适配器
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;
import com.example.laowang.android0824.R;
import com.example.laowang.android0824.module.Student;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

/**
 * Created by Administrator on 2015/8/24.
 */
public class StudentAdapter extends BaseAdapter {
    private List<Student> mdata;
    private LayoutInflater mInflater;
    public StudentAdapter(LayoutInflater inflater,List<Student> data){
        //将数据和inflater传入适配器中
        mInflater=inflater;
        mdata=data;
    }
    @Override
    public int getCount() {
        //得到ListView的数据条数
        return mdata.size();
    }

    @Override
    public Object getItem(int position) {
        //返回索引
        return position;
    }

    @Override
    public long getItemId(int position) {
//        返回索引
        return position;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        //实现布局和数据的连接,将xml(布局)文件转换成view
//        inflate方法
        View view=mInflater.inflate(R.layout.item_simple_adapter,null);
//        适配器作用是将数据放到view上
//        获得学生数据
        Student student=mdata.get(position);
//        将学生数据放到view上
//        注意此处view.findViewById,不然找不出来
        ImageView iv_img= (ImageView) view.findViewById(R.id.iv_img);
        TextView tv_name= (TextView) view.findViewById(R.id.tv_name);
        TextView tv_age= (TextView) view.findViewById(R.id.tv_age);
        TextView tv_sex= (TextView) view.findViewById(R.id.tv_sex);
        iv_img.setImageResource(student.getImg());
        tv_name.setText(student.getName());
        tv_age.setText(student.getAge());
        tv_sex.setText(student.getSex());
        return view;
    }
}

//布局
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_margin="15dp"
    android:gravity="center_vertical"
    android:orientation="horizontal">
    <ImageView
        android:id="@+id/iv_img"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"

        />
    <TextView
        android:id="@+id/tv_name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="姓名" />

    <TextView
        android:id="@+id/tv_age"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="15dp"
        android:text="年龄" />

    <TextView
        android:id="@+id/tv_sex"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="性别" />
</LinearLayout>

//活动
import android.app.Activity;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import com.example.laowang.android0824.adapter.StudentAdapter;
import com.example.laowang.android0824.module.Student;

import java.lang.reflect.Array;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

public class MyListActivity extends Activity {
    private ListView mlistView;
//    String[] array={"张三","李四","王五","赵六"};
    private List<Student> mdata;
//    private List<HashMap<String,String>> mdata;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_list_view);
        mlistView= (ListView) findViewById(R.id.listView);
//        自定义适配器相关代码块
//      获得存在的LayoutInflater
        LayoutInflater inflater=getLayoutInflater();
        initmdata();
        //initmdata要写在构造适配器之前,不然没有数据会报空指针
//        将LayoutInflater和mdata数据传到适配器中
        StudentAdapter adapter=new StudentAdapter(inflater,mdata);
//      系统调用适配器中的方法
        mlistView.setAdapter(adapter);

    }
//      自定义适配器的mdata初始化模块
    private void initmdata() {
        mdata=new ArrayList<>();
        Student zhangsan=new Student("张三","27","女",R.mipmap.anglebaby);
        mdata.add(zhangsan);
        Student lisi=new Student("李四","27","女",R.mipmap.anglebaby);
        mdata.add(lisi);
        Student wangwu=new Student("李华","27","女",R.mipmap.anglebaby);
        mdata.add(wangwu);
    }
}

这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值