栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

【无标题】

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

【无标题】

1.简单的登录界面

1.实验要求
(1)熟练使用Button控件,熟练使用4种按钮监听方法;
(2)熟练掌握线性布局的方法,掌握EditBox控件中信息的获取方法;
(3)实现一个登录界面,用户输入用户名和密码,单击登录按钮,会显示用户输入的用户名和密码。
2.实验环境
(1)软件环境:Android Studio Arctic Fox (2020.3.1);
(2)硬件环境:PC机
3.实验步骤
(1)创建新项目:新建一个Empty Activity,项目名称为LoginDemo。
(2)添加控件: 在activity_main.xml中添加用户名、密码和登录按钮,其中用户名和密码使用EditText控件,登录按钮使用Button控件,为每一个控件设置对应的ID。
(3)设计界面:单击“Design”选项卡,设计登录界面。
(4)设置按钮的单击事件:在MainActivity中初始化控件,设置按钮单击事件,使用接口的方式,在类的声明中加入implements View.OnClickListener,然后使用login.setonClickListener(this)进行监听,最后定义onClick方法进行监听事件的处理。
(5)运行项目,查看结果。
4.实验代码
(1)activity_main.xml布局文件




    

    

    

    

(2)MainActivity.java文件

package com.example.logindemo;

import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity implements View.OnClickListener {

        private Button login;
        private EditText username;
        private EditText password;

        @Override
        protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        initView();
        login.setOnClickListener(this);
    }

    private void initView() {
        username = (EditText) findViewById(R.id.username);
        password = (EditText) findViewById(R.id.password);
        login = (Button) findViewById(R.id.btn_login);

    }

    public void onClick(View view) {
        switch (view.getId()) {
            case R.id.btn_login:
                String msg="您输入的用户名是“"+username.getText()+"”,密码是“"+password.getText()+"”";
                 Toast toast=Toast.makeText(this, msg, Toast.LENGTH_LONG);
                 View v=toast.getView();
                 v.setBackgroundResource(R.color.LightSkyBlue);
                 toast.setView(v);
                 toast.show();
                break;
            default:
                break;
        }
    }
}

5.实验结果截图
(1)初始界面

(2)登录按钮监听事件

2. ListView的简单使用

1.实验要求
(1)熟悉ListView组件的使用,学习适配器的使用;
(2)练习使用ListView组件中的按钮进行监听事件的设置;
(3)使用简单的ListView显示列表,以宝宝相册为例,实现一个带有一个按钮、一个图片和两行字的列表,单击按钮时显示图片的详细信息。
2.实验环境
(1)硬件环境:PC机
(2)软件版本:Android Studio Arctic Fox (2020.3.1)
3.实验步骤
(1)创建新项目:新建一个Empty Activity,项目名称为SimpleAdapterDemo。
(2)布局文件:定义一个用来显示一个列内容的xml,因为系统没有对应的布局文件可用,可以自己定义一个布局文件,命名为list_item.xml,在其中加入图片、标题和信息以及显示按钮,其中图片为ImageView控件,标题和信息为TextView控件,显示按钮view为Button控件,为每一个控件添加ID。
(3)加载ListView: 在activity_main.xml文件中加入ListView组件,并为其设置ID为news_list。
(4)MainActivity:在MainActivity.java文件中,定义并绑定MyAdapter,MyAdapter继承baseAdapter,最主要的代码就是getView方法的实现 ,在getView中使用了ViewHolder类和对象。用ViewHolder,主要是进行一些性能优化,减少一些不必要的重复操作。ViewHolder是一个内部类,其中包含单个项目布局中的各个控件。
(5)getView方法:系统显示列表时,首先实例化自定义的适配器,当手动完成适配时,必须手动映射数据,这就需要重写getView方法。系统在绘制列表的每一行时将调用此方法。getView()有3个参数,position表示将要显示的是第几行,covertView是从布局文件中加载的单个item的布局,parent是ListView。这里采用LayoutInflater的方法将定义好的list_item.xml文件提取成view实例用来显示,然后将xml文件中的各个组件实例化,这样就可以将数据对应到各个组件上了。
按钮为了响应单击事件,需要为它添加单击监听器,这样就能捕获单击事件。onClick中调用showInfo(position)。
(6)showInfo方法:在showInfo方法中使用了alertDialog进行信息的显示。因为按钮的onClick传递了position值,showInfo就可以操作position位置的数据了。
(7)运行项目,查看结果。
4.实现代码
(1)activity_main.xml




    



(2)list_item.xml




    

    

        

        

        

(3)MainActivity.java

package com.example.simpleadapterdemo;

import androidx.appcompat.app.alertDialog;
import androidx.appcompat.app.AppCompatActivity;

import android.content.Context;
import android.content.DialogInterface;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.baseAdapter;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class MainActivity extends AppCompatActivity {

    private ListView news_list;
    private  List> mData;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        news_list=(ListView)findViewById(R.id.news_list);
        mData=getData();
        MyAdapter adapter= new MyAdapter(this);
        news_list.setAdapter(adapter);
    }

    private List>getData(){
        List> list = new ArrayList>();
        Map map =new HashMap();
        map.put("news_title","毡帽系列");
        map.put("news_info","此系列服装有点cute,像不像小车夫");
        map.put("news_thumb",R.drawable.i1);
        list.add(map);

        map = new HashMap();
        map.put("news_title","蜗牛系列");
        map.put("news_info","宝宝变成了小蜗牛,爬啊爬啊爬啊爬");
        map.put("news_thumb",R.drawable.i2);
        list.add(map);

        map = new HashMap();
        map.put("news_title","小蜜蜂系列");
        map.put("news_info","小蜜蜂,嗡嗡嗡,飞到西,飞到东");
        map.put("news_thumb",R.drawable.i3);
        list.add(map);

        map = new HashMap();
        map.put("news_title","毡帽系列");
        map.put("news_info","这个小朋友的衣服好可爱,像一个小车夫");
        map.put("news_thumb",R.drawable.i4);
        list.add(map);

        map = new HashMap();
        map.put("news_title","小蜜蜂系列");
        map.put("news_info","小蜜蜂,嗡嗡嗡嗡嗡嗡嗡嗡");
        map.put("news_thumb",R.drawable.i5);
        list.add(map);

        map = new HashMap();
        map.put("news_title","蜗牛系列");
        map.put("news_info","小蜗牛,爬呀爬");
        map.put("news_thumb",R.drawable.i6);
        list.add(map);
        return list;
    }

    public final class ViewHolder{
        public ImageView news_thumb;
        public TextView news_title;
        public TextView news_info;
        public Button news_btn;
    }

    public  class MyAdapter extends baseAdapter{
        public LayoutInflater mInflater;
        public MyAdapter(Context context){
            this.mInflater = LayoutInflater.from(context);
        }
        @Override
        public int getCount() {
            return mData.size();
        }

        @Override
        public Object getItem(int arg0) {
            return null;
        }

        @Override
        public long getItemId(int arg0) {
            return 0;
        }

        @Override
        public View getView( final int position, View convertView, ViewGroup parent) {
            ViewHolder viewHolder =null;
            if(convertView==null){
                viewHolder =new ViewHolder();
                convertView=mInflater.inflate(R.layout.list_item,null);
                viewHolder.news_thumb=(ImageView)convertView.findViewById(R.id.news_thumb);
                viewHolder.news_title=(TextView)convertView.findViewById(R.id.news_title);
                viewHolder.news_info=(TextView)convertView.findViewById(R.id.news_info);
                viewHolder.news_btn=(Button) convertView.findViewById(R.id.news_btn);
                convertView.setTag(viewHolder);
            }else{
                viewHolder=(ViewHolder) convertView.getTag();
            }
            viewHolder.news_thumb.setBackgroundResource((Integer)mData.get(position).get("news_thumb"));
            viewHolder.news_title.setText((String)mData.get(position).get("news_title"));
            viewHolder.news_info.setText((String)mData.get(position).get("news_info"));
viewHolder.news_btn.setTag(position);
viewHolder.news_btn.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    showInfo(position);
                }
            });

            return convertView;
        }

    }

public  void showInfo(int position){
        new alertDialog.Builder(this).setTitle(mData.get(position).get("news_title").toString())
                .setMessage(mData.get(position).get("news_info").toString())
                .setPositiveButton("确定", new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialogInterface, int which) {

                    }
                })
        .show();
    }

}

5.实验结果截图
(1)带按钮的ListView显示效果 (2)ListView 按钮单击效果

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/631956.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号