IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> 【无标题】 -> 正文阅读

[移动开发]【无标题】

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布局文件


<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <TextView
        android:id="@+id/textView"
        android:layout_width="264dp"
        android:layout_height="28dp"
        android:layout_marginStart="4dp"
        android:text="欢迎登录本系统!"
        android:textAlignment="viewStart"
        android:textAppearance="@style/TextAppearance.AppCompat.Body1"
        android:textSize="20sp"
        app:layout_constraintBottom_toTopOf="@+id/username"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.294"
        tools:ignore="MissingConstraints" />

    <EditText
        android:id="@+id/username"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginTop="88dp"
        android:hint="用户名"
        android:minHeight="48dp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="1.0"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        tools:ignore="MissingConstraints" />

    <EditText
        android:id="@+id/password"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:hint="密码"
        android:inputType="textPassword"
        android:minHeight="48dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.0"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.314"
        tools:ignore="MissingConstraints" />

    <Button
        android:id="@+id/btn_login"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="68dp"
        android:text="登录"
        android:textSize="20sp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.111"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/password"
        tools:ignore="MissingConstraints" />
</androidx.constraintlayout.widget.ConstraintLayout>

(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

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <ListView
        android:id="@+id/news_list"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"      
</ListView>

</LinearLayout>

(2)list_item.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="horizontal"
    tools:visibility="visible">

    <ImageView
        android:id="@+id/news_thumb"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="5dp" />

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

        <TextView
            android:id="@+id/news_title"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textSize="18sp" />

        <TextView
            android:id="@+id/news_info"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textSize="14sp" />

        <Button
            android:id="@+id/news_btn"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="view"
            android:textSize="10sp" />

    </LinearLayout>
</LinearLayout>

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

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

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

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

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

        map = new HashMap<String,Object>();
        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 按钮单击效果

在这里插入图片描述

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2021-12-03 13:09:04  更:2021-12-03 13:10:41 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年10日历 -2024/10/28 4:21:05-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码