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 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> Android -> 正文阅读

[移动开发]Android

Android 学习

1、Android基础开发 – 控件

1、TextView:

  1. 基础属性详解

    1. layout_width:组件的宽度
    2. layout_height:组件的高度
    3. id:为TextView设置一个组件id
    4. text:设置显示的文本内容
    5. textColor:设置字体颜色
    6. textStyle:设置字体风格,三个可选值:normal(无效果),bold(加粗),italic(斜体)
    7. textSize:字体大小,单位一般使用sp
    8. backgroup:控件的背景颜色,可以理解为填充整个控件的颜色,可以是图片
    9. gravity:设置控件中内容的对齐方向,TextView中是文字,ImageView中是图片等等

    activity_main.xml

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical">
    
        <TextView
            android:id="@+id/tv_one"
            android:layout_width="200dp"
            android:layout_height="200dp"
            android:text="@string/tv_one"
            android:textColor="@color/blue"
            android:textStyle="italic"
            android:textSize="30sp"
            android:background="@color/back"
            android:gravity="center"/>
    </LinearLayout>
    

    strings.xml

    <resources>
        <string name="app_name">Controls-TextView</string>
    
        <string name="tv_one">android控件之TextView</string>
    </resources>
    

    colors.xml

    <?xml version="1.0" encoding="utf-8"?>
    <resources>
        <color name="purple_200">#FFBB86FC</color>
        <color name="purple_500">#FF6200EE</color>
        <color name="purple_700">#FF3700B3</color>
        <color name="teal_200">#FF03DAC5</color>
        <color name="teal_700">#FF018786</color>
        <color name="black">#FF000000</color>
        <color name="white">#FFFFFFFF</color>
    
        <color name="blue">#FF0000FF</color>
        <color name="back">#FFFF0000</color>
    </resources>
    

在这里插入图片描述

  1. 带阴影的TextView

    1. android:shadowColor:设置阴影颜色,需要与shadowRadius一起使用
    2. android:shadowRadius:设置阴影的模糊程度,设为0.1就变成字体颜色了,建议用3.0
    3. android:shadowDx:设置阴影在水平方向的偏移,就是水平方向阴影开始的横坐标位置
    4. android:shadowDy:设置阴影在竖直方向的偏移,就是竖直方向阴影开始的纵坐标位置

    activity_main.xml

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical">
    
        <!-- shadowRadius : 模糊度 -->
        <TextView
            android:id="@+id/tv_one"
            android:layout_width="match_parent"
            android:layout_height="200dp"
            android:text="@string/tv_one"
            android:textColor="@color/blue"
            android:textStyle="italic"
            android:textSize="30sp"
            android:background="@color/back"
            android:gravity="center"
            android:shadowColor="@color/red"
            android:shadowRadius="3.0"
            android:shadowDx="10.0"
            android:shadowDy="10.0"
            android:singleLine="true"
            android:ellipsize="marquee"
            android:marqueeRepeatLimit="marquee_forever"/>
    </LinearLayout>
    

    colors.xml

    <?xml version="1.0" encoding="utf-8"?>
    <resources>
        <color name="purple_200">#FFBB86FC</color>
        <color name="purple_500">#FF6200EE</color>
        <color name="purple_700">#FF3700B3</color>
        <color name="teal_200">#FF03DAC5</color>
        <color name="teal_700">#FF018786</color>
        <color name="black">#FF000000</color>
        <color name="white">#FFFFFFFF</color>
    
        <color name="blue">#FF000000</color>
        <color name="back">#00000000</color>
        <color name="red">#FFF00000</color>
    </resources>
    

在这里插入图片描述

  1. 实现跑马灯效果的 TextView

    1. android:singleLine:内容单行显示
    2. android:focusable:是否可以获取焦点
    3. android:focusableInTouchMode:用于控制视图在触摸模式下是否可以聚焦
    4. android:ellipsize:在哪里省略文本
    5. android:marqueeRepeatLimit:字幕动画重复的次数

    activity_main.xml

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical">
    
        <!-- shadowRadius : 模糊度 -->
        <TextView
            android:id="@+id/tv_one"
            android:layout_width="match_parent"
            android:layout_height="200dp"
            android:text="@string/tv_one"
            android:textColor="@color/blue"
            android:textStyle="italic"
            android:textSize="30sp"
            android:background="@color/back"
            android:gravity="center"
            android:shadowColor="@color/red"
            android:shadowRadius="3.0"
            android:shadowDx="10.0"
            android:shadowDy="10.0"
            android:singleLine="true"
            android:ellipsize="marquee"
            android:marqueeRepeatLimit="marquee_forever"
            android:focusable="true"
            android:focusableInTouchMode="true" />
        <requestFocus/> <!-- 获取焦点 -->
    </LinearLayout>
    

在这里插入图片描述

效果 : 滚动显示所有的文字

2、Button

  1. StateListDrawable

    StateListDrawable是Drawable资源的一种,可以根据不同的状态,设置不同的图片效果,关键节点,我们只需要将Button的background属性设置为该drawable资源即可轻松实现,按下按钮时不同的按钮颜色或背景

    1. drawable:引用的Drawable位图
    2. state_focused:是否获取焦点
    3. state_pressed:控件是否被挤下
    4. state_enabled:控件是否可用
    5. state_selected:控件是否被选择,针对有滚轮的情况
    6. state_checked:控件是否被勾选
    7. state_checkable:控件可否被勾选,eg:checkbox
    8. state_window_focused:是否获得窗口焦点
    9. state_active:控件是否处于活动状态,eg:slidingTab
    10. state_single:控件包含多个子控件时,确定是否只显示一个子控件
    11. state_first:软件包含多个子控件时,确定第一个子控件是否处于显示状态
    12. state_middle:控件包含多个子控件时,确定中间一个子控件是否处于显示状态
    13. state_last:控件包含多个子控件时,确定最后一个子控件是否处于显示状态

    activity_main.xml

    <?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:orientation="vertical">
    
        <Button
            android:text="我是按钮"
            android:background="@drawable/btn_selector"
            android:backgroundTint="@color/btn_color_selector"
            android:layout_width="200dp"
            android:layout_height="100dp"/>
    
    </LinearLayout>
    

    btn_selector.xml

    <?xml version="1.0" encoding="utf-8"?>
    <selector xmlns:android="http://schemas.android.com/apk/res/android">
    
        <!-- android:state_pressed="true" 按钮按钮显示 -->
        <item android:drawable="@drawable/ic_baseline_agriculture_24" android:state_pressed="true"/>
        <item android:drawable="@drawable/ic_baseline_accessibility_24"/>
    
    </selector>
    

    btn_color_selector.xml

    <?xml version="1.0" encoding="utf-8"?>
    <selector xmlns:android="http://schemas.android.com/apk/res/android">
    
        <item android:color="#ffff0000" android:state_pressed="true"/>
        <item android:color="#ff00ff00"/>
    
    </selector>
    

在这里插入图片描述

在这里插入图片描述

  1. Button事件处理

    1. 点击事件
    2. 长按事件
    3. 触摸事件

    activity_main.xml

    <?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:orientation="vertical">
    
        <Button
            android:id="@+id/btn"
            android:text="我是按钮"
            android:background="@drawable/btn_selector"
            android:backgroundTint="@color/btn_color_selector"
            android:layout_width="200dp"
            android:layout_height="100dp"/>
    
    </LinearLayout>
    

    MainActivity

    package com.tinno.controls_button;
    
    import androidx.appcompat.app.AppCompatActivity;
    
    import android.os.Bundle;
    import android.util.Log;
    import android.view.MotionEvent;
    import android.view.View;
    import android.widget.Button;
    
    public class MainActivity extends AppCompatActivity {
    
        private static final String TAG = "tinno";
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
    
            Button btn = findViewById(R.id.btn);
    
            //点击事件
            btn.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    Log.e(TAG, "onClick: ");
                }
            });
    
            // 长按事件
            btn.setOnLongClickListener(new View.OnLongClickListener() {
                @Override
                public boolean onLongClick(View view) {
                    Log.e(TAG, "onLongClick: " );
                    return false;
                }
            });
    
            //触摸事件
            btn.setOnTouchListener(new View.OnTouchListener() {
                @Override
                public boolean onTouch(View view, MotionEvent motionEvent) {
                    Log.e(TAG, "onTouch: " + motionEvent.getAction() );
                    return false;
                }
            });
        }
    }
    

在这里插入图片描述

3、EditText

  1. 主要属性

    1. android:hint:输入提示
    2. android:textColorHint:输入提示的内容
    3. android:inputType:输入类型
    4. android:drawableXxx:在输入框的指定方位添加图片
    5. android:drawablePadding:设置图片与输入内容的间距
    6. android:paddingXxxx:设置内容与边框的间距
    7. android:background:背景色

    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:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        tools:context=".MainActivity">
    
    
        <EditText
            android:id="@+id/et"
            android:hint="请输入用户名"
            android:textColorHint="#95A1AA"
            android:inputType="phone"
            android:layout_width="200dp"
            android:layout_height="100dp" />
    
        <EditText
            android:hint="请输入密码"
            android:textColorHint="#95A1AA"
            android:inputType="textPassword"
            android:drawableLeft="@drawable/ic_baseline_alt_route_24"
            android:drawablePadding="20dp"
            android:paddingLeft="20dp"
            android:background="@color/white"
            android:layout_width="200dp"
            android:layout_height="100dp" />
    
        <Button
            android:id="@+id/btn"
            android:text="获取用户名"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"/>
    </LinearLayout>
    

    MainActivity

    package com.tinno.controls_edittext;
    
    import androidx.appcompat.app.AppCompatActivity;
    
    import android.os.Bundle;
    import android.util.Log;
    import android.view.View;
    import android.widget.Button;
    import android.widget.EditText;
    
    public class MainActivity extends AppCompatActivity {
    
        private EditText et;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
    
            Button btn = findViewById(R.id.btn);
            et = findViewById(R.id.et);
    
            /* 点击按钮获取EditText的内容 */
            btn.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    String text = et.getText().toString();
                    Log.e("TAG", "输入的内容: " + text);
                }
            });
        }
    }
    

在这里插入图片描述

4、ImageView

  1. 主要属性

    1. android:src:设置图片资源
    2. android:scaleType:设置图片缩放类型
    3. android:maxHeight:最大高度
    4. android:maxWidth:最大宽度
    5. android:adjustViewBounds:调整View的界限
  2. 缩放类型

    1. fitStart:保持宽高比缩放图片,直到较长的边与Image的边长相等,缩放完成后将图片放在ImageView的左上角
    2. fitCenter:默认值,同上,缩放后放于中间
    3. fitEnd:同时,缩放后放于右下角
    4. fixXY:对图像的横纵方向进行独立缩放,使得该图片完全适应ImageView,但是图片的宽高比可能发生改变
    5. center:保持原图大小,显示在ImageView的中心。当原图的size大于ImageView的size,超过部分裁剪处理
    6. centerCrop:保持宽高比缩放图片,直到完全覆盖ImageView,可能会出现图片的显示不完全
    7. centerInside:保持宽高比缩放图片,直到ImageView能够完全显示图片
    8. matrix:不改变原图的大小,从ImageView的左上角开始绘制原图,原图超过ImageView的部分做裁剪处理

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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"
    android:orientation="vertical">

    <ImageView
        android:src="@drawable/ic_ceshi1"
        android:scaleType="fitStart"
        android:layout_width="200dp"
        android:layout_height="200dp"/>

    <ImageView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/ic_ceshi2"
        android:maxHeight="200dp"
        android:maxWidth="200dp"
        android:adjustViewBounds="true"
        android:scaleType="fitXY" />
</LinearLayout>

在这里插入图片描述

5、ProgressBar (进度条)

  1. 常用属性详解

    1. android:max:进度条的最大值
    2. android:progress:进度条已完成进度值
    3. android:indeterminate:如果设置成true,则进度条不精确显示进度
    4. style="?android:attr/progressBarStyleHorizontal":水平进度条

activity_main.xml

<?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:orientation="vertical">

    <ProgressBar
        android:id="@+id/pb"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>

    <Button
        android:text="显示隐藏进度条"
        android:onClick="tinnoClick"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>

    <ProgressBar
        android:id="@+id/pb2"
        style="?android:attr/progressBarStyleHorizontal"
        android:max="100"
        android:layout_width="300dp"
        android:layout_height="wrap_content"/>

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="模拟下载进度"
        android:onClick="load"/>

    <ProgressBar
        style="?android:attr/progressBarStyleHorizontal"
        android:layout_width="300dp"
        android:layout_height="wrap_content"
        android:indeterminate="true"
        android:max="100" />


</LinearLayout>

MainActivity.java

package com.tinno.controls_progressbar;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.view.View;
import android.widget.ProgressBar;

public class MainActivity extends AppCompatActivity {

    private ProgressBar progressBar;
    private ProgressBar progressBar2;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        progressBar = findViewById(R.id.pb);
        progressBar2 = findViewById(R.id.pb2);
    }

    public void tinnoClick(View view){
        // 单击进度条消失,再次单击进度条显示
        if (progressBar.getVisibility() == View.GONE){
            progressBar.setVisibility(View.VISIBLE);
        }else {
            progressBar.setVisibility(View.GONE);
        }
    }

    public void load(View view){
        // 获得progressbar控件,并进行修改
        int progress = progressBar2.getProgress();
        progress += 10;
        progressBar2.setProgress(progress);
    }
}

在这里插入图片描述

6、Notification (通知)

  1. 在这里插入图片描述

  2. NotificationChannel

    通知渠道:Android 8.0引入了通知渠道,其允许您为要显示的每种通知类型创建用户可自定义的渠道

    通知的重要程度设置,NotificationManager类中

    • IMPORTANCE_NONE:关闭通知
    • IMPORTANCE_MIN:开启通知,不会弹出,但没有提示音,状态栏中无显示
    • IMPORTANCE_LOW:开启通知,不会弹出,不发出提示音,状态栏中显示
    • IMPORTANCE_DEFAULT:开启通知,不会弹出,发出提示音,状态栏中显示
    • IMPORTANCE_HIGH:开启通知,会弹出,发出提示音,状态栏中显示
  3. 常见方法说明

    1. setContentTitle(String string):设置标题
    2. setContentText(String string):设置文本内容
    3. setSmallIcon(int icon):设置小图标
    4. setLargeIcon(Bitmap icon):设置通知的大图标
    5. setColor(int argb):设置小图片的颜色
    6. setContentIntent(PendingIntend intend):设置点击通知后的跳转意图
    7. setAutoCancel(boolean boolean):设置点击通知后自动清除通知
    8. setWhen(long when):设置通知被创建的时间
  4. 注意点

    Android从5.0开始,对于通知栏图标的设计进行了修改。

    现在Google要求,所有应用程序的通知栏图标,应该只能使用alpha图层来进行绘制,而不应该包括RGB图层 ==>(图片不能带颜色)

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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"
    android:orientation="vertical">

    <Button
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:onClick="sendNotification"
    android:text="发出通知"/>

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="cacelNotification"
        android:text="取消通知"/>

</LinearLayout>

MainActivity.java

package com.tinno.controls_notification;

import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.NotificationCompat;

import android.app.Notification;
import android.app.NotificationChannel;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.Intent;
import android.graphics.BitmapFactory;
import android.graphics.Color;
import android.os.Build;
import android.os.Bundle;
import android.view.View;

public class MainActivity extends AppCompatActivity {

    private NotificationManager manager;
    private Notification notification;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        manager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);

        //进行版本判断
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O){
            NotificationChannel channel =
                    new NotificationChannel("tinno", "测试通知", NotificationManager.IMPORTANCE_HIGH);//之间的id需要和后文中的new NotificationCompat.Builder(this,"tinno")相等
            manager.createNotificationChannel(channel); //形成一个绑定关系
        }
		
        //设置跳转的页面
        Intent intent = new Intent(this, NotificationActivity.class);
        PendingIntent pendingIntent = PendingIntent.getActivity(this,0,intent,0);

        notification = new NotificationCompat.Builder(this,"tinno")
                .setContentTitle("官方通知") //设置标题
                .setContentText("世界那么大,我想去看看") //设置文本内容
                .setSmallIcon(R.drawable.ic_frined) //设置小图标
                .setLargeIcon(BitmapFactory.decodeResource(getResources(),R.drawable.ic_ceshi1)) //设置大图标
                .setColor(Color.parseColor("#ff0000")) //设置小图标颜色
                .setContentIntent(pendingIntent) //设置点击通知后的跳转意图
                .setAutoCancel(true)    //设置点击通知后自动清除通知 -> 自动取消
                .build();
    }

    // 发出通知按钮
    public void sendNotification(View view){
        manager.notify(1,notification);
    }

    //点击取消通知
    public void cacelNotification(View view){
        manager.cancel(1); //两个id必须一致
    }
}

NotificationActivity.java 跳转的页面

package com.tinno.controls_notification;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;

import androidx.annotation.Nullable;

public class NotificationActivity extends Activity {
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        Log.e("leo", "onCreate: 进入NotificationActivity");
    }
}

在这里插入图片描述

7、Toolbar (标题栏)

  1. 常用属性详解

    1. android:layout_width=“match_parent”
    2. android:layout_height="?attr/actionBarSize"
    3. android:background="#ffff00"
    4. app:navigationIcon="@drawable/ic_baseline_arrow_back_24"
    5. app:title=“主标题”
    6. app:titleTextColor="#ff0000"
    7. app:titleMarginStart=“90dp” 距离左边距离
    8. app:subtitle=“子标题”
    9. app:subtitleTextColor="#00ffff"
    10. app:logo="@mipmap/ic_launcher"

    activity_main.xml

    <?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"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:orientation="vertical">
    
        <androidx.appcompat.widget.Toolbar
            android:id="@+id/tb"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="#ffff00"
            app:navigationIcon="@drawable/ic_baseline_arrow_back_24"
            app:title="标题"
            app:titleTextColor="#ff0000"
            app:titleMarginStart="90dp"
            app:subtitle="子标题"
            app:subtitleTextColor="#00ffff"
            app:logo="@mipmap/ic_launcher"/>
    
        <androidx.appcompat.widget.Toolbar
            android:id="@+id/tb2"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="#ffff00"
            android:layout_marginTop="10dp"/>
    
        <!-- 将toolbar的标题放在中间 -->
        <androidx.appcompat.widget.Toolbar
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="#ffff00"
            app:navigationIcon="@drawable/ic_baseline_arrow_back_24"
            android:layout_marginTop="10dp">
    
            <TextView
                android:text="标题3"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center"/>
    
        </androidx.appcompat.widget.Toolbar>
    
    </LinearLayout>
    

    MainActivity.java

    package com.tinno.controls_toolbar;
    
    import androidx.appcompat.app.AppCompatActivity;
    import androidx.appcompat.widget.Toolbar;
    
    import android.os.Bundle;
    import android.util.Log;
    import android.view.View;
    
    public class MainActivity extends AppCompatActivity {
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
    
            Toolbar toolbar = findViewById(R.id.tb);
    
            toolbar.setNavigationOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    Log.e("tinno", "onClick: toolbar1被点击了" );
                }
            });
    
            Toolbar toolbar2 = findViewById(R.id.tb2);
            toolbar2.setNavigationIcon(R.drawable.ic_baseline_arrow_back_24);
            toolbar2.setTitle("标题2");
            toolbar2.setNavigationOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    Log.e("tinno", "onClick: toolbar2被点击了" );
                }
            });
        }
    }
    

在这里插入图片描述

8、AlertDialog

  1. 实现方式

    1. AlertDialog.Builder builder = new AlertDialog.Builder(context); 构建Dialog的各种参数
    2. Builder.setIcon(int iconId); 添加icon
    3. Builder.setTitle(CharSequence title); 添加标题
    4. Builder.setMessage(View view);设置自定义布局
    5. Builder.create(); 创建Dialog
    6. Builder.show(); 显示对话框
    7. setPositiveButton 确定按钮
    8. setNegativeButton 取消按钮
    9. setNeutralButton 中间按钮

    activity_main.xml

    <?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:orientation="vertical">
    
       <Button
           android:layout_width="wrap_content"
           android:layout_height="wrap_content"
           android:text="显示对话框"
           android:onClick="tinnoClick"/>
    
    </LinearLayout>
    

    MainActivity.java

    package com.tinno.controls_alertdialog;
    
    import androidx.appcompat.app.AppCompatActivity;
    
    import android.app.AlertDialog;
    import android.content.DialogInterface;
    import android.os.Bundle;
    import android.util.Log;
    import android.view.View;
    
    public class MainActivity extends AppCompatActivity {
    
        public static final String TAG = "tinno";
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
        }
    
        public void tinnoClick(View view){
    
            //将布局加载变为一个view
            View dialogView = getLayoutInflater().inflate(R.layout.dialog_view, null);
    
            AlertDialog.Builder builder = new AlertDialog.Builder(this);
            builder.setIcon(R.mipmap.ic_launcher)
                    .setTitle("我是对话框")
                    .setMessage("今天天气不错")
                    .setPositiveButton("确认", new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialogInterface, int i) {
                            Log.e(TAG, "onClick: 点击了确认按钮" );
                        }
                    })
                    .setNegativeButton("取消", new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialogInterface, int i) {
                            Log.e(TAG, "onClick: 点击了取消按钮" );
                        }
                    })
                    .setNeutralButton("中间", new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialogInterface, int i) {
                            Log.e(TAG, "onClick: 点击了中间按钮" );
                        }
                    })
                    .setView(dialogView)    //设置自定义布局
                    .create()   //创建对话框
                    .show();    //显示对话框
        }
    }
    

    dialog_view.xml

    <?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:orientation="horizontal"
        android:background="#ffff00">
    
        <ImageView
            android:src="@mipmap/ic_launcher"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"/>
    
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="哈哈哈!今天天气不错"/>
    
    </LinearLayout>
    

    在这里插入图片描述

8、PopupWindow

  1. setContentView(View contentView):设置PopupWindow显示的View
  2. showAsDropDown(View anchor):相对某个控件的位置(正左下方),无偏移
  3. showAsDropDown(View anchor,int xoff,int yoff):相对某个控件的位置,有偏移
  4. setFocusable(boolean focusable):设置是否获取焦点
  5. setBackgroundDrawable(Drawable background):设置背景
  6. dismiss():关闭弹窗
  7. setAnimationStyle(int animationStyle):设置加载动画
  8. setTouchable(boolean touchable):设置触摸技能
  9. setOutsideTouchable(boolean touchable):设置PopupWindow外面的触摸使能

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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"
    android:orientation="vertical">

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="弹出PopupWindow"
        android:onClick="tinnoClick"/>

</LinearLayout>

popup_view.xml

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

    <Button
        android:id="@+id/btn1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:padding="5dp"
        android:text="上海"
        android:textSize="18sp"/>

    <Button
        android:id="@+id/btn2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:padding="5dp"
        android:text="北京"
        android:textSize="18sp"/>
</LinearLayout>

MainActivity.java

package com.tinno.controls_popupwindow;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.PopupWindow;

public class MainActivity extends AppCompatActivity {

    public static final String TAG = "tinno";

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

    public void tinnoClick(View view){
        View popupView = getLayoutInflater().inflate(R.layout.popup_view, null);

        //获取处在popup_view中的两个按钮
        Button btn1 = popupView.findViewById(R.id.btn1);
        Button btn2 = popupView.findViewById(R.id.btn2);

        //调用PopupWindow的构造函数,将内容显示,(view对象【布局文件】,长度,宽度,是否获取焦点)
        PopupWindow popupWindow = new PopupWindow(popupView, ViewGroup.LayoutParams.WRAP_CONTENT,ViewGroup.LayoutParams.WRAP_CONTENT,true);

        //为popupwindow设置背景图片
        popupWindow.setBackgroundDrawable(getResources().getDrawable(R.drawable.ic_ceshi1));

        //设置相对某个控件的位置(正左下方),无偏移
        popupWindow.showAsDropDown(view);

        //为两个按钮设置点击事件
        btn1.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Log.e(TAG, "onClick: 你是住在上海吗" );
                popupWindow.dismiss();  //点击之后关闭窗口
            }
        });

        btn2.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Log.e(TAG, "onClick: 你是住在北京吗" );
                popupWindow.dismiss();
            }
        });
    }
}

在这里插入图片描述

2、Android基础开发 – 布局

2.1、LinearLayout(线性布局)

  1. orientation:布局中组件的排列方式
  2. gravity:控制组件所包含的子元素的对齐方式,可多个组合
  3. layout_gravity:控制组件在父容器里的对齐方式
  4. background:为该组件设置一个背景图片,或者是直接用颜色覆盖
  5. divider:分割线
  6. showDividers:设置分割线所在的位置,none(无),beginning(开始),end(结束),middle(每两个组件间)
  7. dividerPadding:设置分割线的padding
  8. layout_wright(权重):该属性是用来等比例的划分区域的

avtivity_main.xml

<?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:orientation="vertical"
    android:divider="@drawable/divider"
    android:showDividers="middle"
    android:dividerPadding="100dp">

    <!--
        android:orientation="vertical"  ==>纵向排序
        android:gravity="center_vertical" ==> 垂直方向居中
        android:gravity="center_horizontal|bottom" ==> 水平方向居中并在底部
    -->

    <LinearLayout
        android:background="#ff0000"
        android:layout_width="100dp"
        android:layout_height="0dp" 
        android:layout_weight="2"/>
        
    <!-- 可以用view进行分割线的绘制 -->
    <View
        android:background="#00ff00"
        android:layout_width="match_parent"
        android:layout_height="1dp"/>

    <LinearLayout
        android:background="#ffff00"
        android:layout_width="100dp"
        android:layout_height="0dp"
        android:layout_weight="1"/>

    <LinearLayout
        android:background="#ff00ff"
        android:layout_width="100dp"
        android:layout_height="0dp"
        android:layout_weight="1"/>
</LinearLayout>

在这里插入图片描述

2.2、RelativeLayout(相对布局,以父容器为基准)

  1. 常见属性

    根据父容器定位

    1. layout_alignParentLeft:左对齐
    2. layout_alignParentRight:右对齐
    3. layout_alignParentTop:顶部对齐
    4. layout_alignParentBottom:底部对齐
    5. layout_centerVertical:垂直居中
    6. layout_centerInParent:中间位置

    根据兄弟组件定位

    1. layout_toLeftOf:放置于参考组件的左边
    2. layout_toRightOf:放置于参考组件的右边
    3. layout_above:放置于参考组件的上方
    4. layout_below:放置于参考组件的下方
    5. layout_alignTop:对齐参考组件的上边界
    6. layout_alignBottom:对齐参考组件的下边界
    7. layout_alignLeft:对齐参考组件的左边界
    8. layout_alignRight:对齐参考组件的右边界
  2. 通用属性

    margin 设置组件与父容器的边距

    1. layout_margin:
    2. layout_marginLeft:
    3. layout_marginRight:
    4. layout_marginTop
    5. layout_marginBotton

    padding 设置组件内部元素的边距

    activity_main.xml

    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:padding="100dp"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
    
        <RelativeLayout
            android:id="@+id/rl1"
            android:layout_width="100dp"
            android:layout_centerInParent="true"
            android:layout_height="100dp"
            android:background="#ff0000"/>
    
        <RelativeLayout
            android:layout_width="100dp"
            android:layout_height="100dp"
            android:background="#00ff00"
            android:layout_marginLeft="100dp" />
    
    </RelativeLayout>
    

在这里插入图片描述

2.3、FrameLayout(帧布局):

从父容器的左上角开始绘制,一个一个往上堆

  1. 常见属性

    1. android:foreground:设置前景
    2. android:foregroundGravity:设置前景位置

avtivity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">


    <FrameLayout
        android:layout_width="400dp"
        android:layout_height="400dp"
        android:background="#ff0000"/>

    <!--
        android:foregroundGravity="right|bottom" => 位置居于右下角
    -->
    <FrameLayout
        android:layout_width="300dp"
        android:layout_height="300dp"
        android:background="#ffff00"
        android:foreground="@drawable/ic_ceshi1"
        android:foregroundGravity="right|bottom"/>

    <FrameLayout
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:background="#00ff00"/>
</FrameLayout>

在这里插入图片描述

2.4、TableLayout(表格布局)

  1. 常见属性

    1. android:collapseColumns:设置需要被隐藏的列的序号,从0开始
    2. android:stretchColumns:设置允许被拉伸的列的列序号,从0开始
    3. android:strinkColumns:设置允许被收缩的列的列序号,从0开始

    子控件设置属性

    1. android:layout_column:现在在第几列
    2. android:layout:span:横向跨几列

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:shrinkColumns="1">

    <TableRow>
        <Button
            android:layout_height="wrap_content"
            android:layout_width="wrap_content"
            android:layout_column="2"
            android:layout_span="2"
            android:text="第1个"/>

        <Button
            android:layout_height="wrap_content"
            android:layout_width="wrap_content"
            android:text="第2个"/>

    </TableRow>

    <TableRow>
        <Button
            android:layout_height="wrap_content"
            android:layout_width="wrap_content"
            android:text="第1个"/>

        <Button
            android:layout_height="wrap_content"
            android:layout_width="wrap_content"
            android:text="第2个"/>

        <Button
            android:layout_height="wrap_content"
            android:layout_width="wrap_content"
            android:text="第3个"/>

        <Button
            android:layout_height="wrap_content"
            android:layout_width="wrap_content"
            android:text="第4个"/>

        <Button
            android:layout_height="wrap_content"
            android:layout_width="wrap_content"
            android:text="第5个"/>


    </TableRow>

    <Button
        android:layout_height="wrap_content"
        android:layout_width="wrap_content"
        android:text="第1个"/>

    <Button
        android:layout_height="wrap_content"
        android:layout_width="wrap_content"
        android:text="第2个"/>

</TableLayout>

在这里插入图片描述

2.5、GridLayout(网格布局)

  1. 常见属性

    1. android:orientation:设置水平显示还是垂直显示
    2. android:columnCount:设置行的显示个数
    3. android:rowCount:设置列的显示个数
  2. 子控件属性

    1. android:layout_column:显示在第几列
    2. android:layout_columnSpan:横向跨几列
    3. android:layout_columnWeight:横向剩余空间分配方式
    4. android:gravity:在网格中的显示位置
    5. android:layout_row:显示在第几列
    6. android:layout_rowSpan:横向跨几列
    7. android:layout_rowWeight:纵向剩余空间分配方式

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<GridLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:columnCount="3">

    <Button
        android:layout_height="wrap_content"
        android:layout_width="wrap_content"
        android:text="第1个" />

    <!--
        android:layout_row="1"
        android:layout_column="0"
        显示在第一行第零列
    -->
    <Button
        android:layout_height="wrap_content"
        android:layout_width="wrap_content"
        android:layout_row="1"
        android:layout_column="0"
        android:layout_rowWeight="1"
        android:layout_columnSpan="2"
        android:layout_gravity="fill"
        android:text="第2个"/>

    <Button
        android:layout_height="wrap_content"
        android:layout_width="wrap_content"
        android:layout_row="2"
        android:text="第3个"/>

    <Button
        android:layout_height="wrap_content"
        android:layout_width="wrap_content"
        android:text="第4个"/>

    <Button
        android:layout_height="wrap_content"
        android:layout_width="wrap_content"
        android:text="第5个"/>

    <Button
        android:layout_height="wrap_content"
        android:layout_width="wrap_content"
        android:text="第6个"/>

    <Button
        android:layout_height="wrap_content"
        android:layout_width="wrap_content"
        android:text="第7个"/>

</GridLayout>

在这里插入图片描述

2.6、ConstraintLayout(约束布局)

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">


    <Button
        android:id="@+id/button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <Button
        android:id="@+id/button2"
        android:layout_width="wrap_content"
        android:layout_height="0dp"
        android:layout_marginTop="60dp"
        android:text="Button"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintStart_toStartOf="@+id/button"
        app:layout_constraintTop_toBottomOf="@+id/button"
        app:layout_constraintVertical_bias="0.0" />

    <androidx.constraintlayout.widget.Guideline
        android:id="@+id/guideline2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_constraintGuide_begin="205dp" />

    <Button
        android:id="@+id/button3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginEnd="60dp"
        android:text="Button"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toStartOf="@+id/guideline2"
        app:layout_constraintTop_toTopOf="parent" />

    <Button
        android:id="@+id/button4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="60dp"
        android:text="Button"
        app:layout_constraintStart_toStartOf="@+id/guideline2"
        app:layout_constraintTop_toTopOf="@+id/button3" />

</androidx.constraintlayout.widget.ConstraintLayout>

在这里插入图片描述

3、Android基础开发 – ListView

list_item.xml

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

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

</LinearLayout>

activity_main.xml

<?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">

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

</LinearLayout>

Bean.java

package com.tinno.my_listview;

public class Bean {

    String name;

    public String getName() {
        return name;
    }

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

MyAdapter.java

package com.tinno.my_listview;

import android.content.Context;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView;

import java.util.List;

public class MyAdapter extends BaseAdapter {

    private List<Bean> data;
    private Context context;


    public MyAdapter(List<Bean> data, Context context) {
        this.data = data;
        this.context = context;
    }

    @Override
    public int getCount() {
        return data.size();
    }

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

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

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        ViewHolder viewHolder;
        if (convertView == null){
            viewHolder = new ViewHolder();
            convertView = LayoutInflater.from(context).inflate(R.layout.list_item, parent,false);
            viewHolder.textView = convertView.findViewById(R.id.tv);
            convertView.setTag(viewHolder);
        }else {
            viewHolder = (ViewHolder) convertView.getTag();
        }
        //获取TextView对象
        //TextView textView = convertView.findViewById(R.id.tv);
        //为TextView赋值
        //textView.setText(data.get(position).getName());
        viewHolder.textView.setText(data.get(position).getName());

        Log.e("tinno", "getView: " + position );

        return convertView;
    }

    //为了优化性能,创建ViewHolder
    private final class ViewHolder{
        TextView textView;
    }
}

MainActivity.java

package com.tinno.my_listview;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ListView;
import android.widget.TextView;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends AppCompatActivity {

    //新建一个list列表,注意:一定要初始化,不然会报空指针异常
    private List<Bean> data = new ArrayList<>();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        //设置显示的内容
        for (int i = 0; i < 100; i++) {
            Bean bean = new Bean();
            bean.setName("Tinno" + i);
            data.add(bean);
        }
        //获取ListView
        ListView listView = findViewById(R.id.lv);
        //设置适配器
        listView.setAdapter(new MyAdapter(data,this));

        // 实现 ListView 的点击
        listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {

                Log.e("tinno", "onItemClick: " + position);
            }
        });
    }
}

在这里插入图片描述

4、Android基础开发 – RecyclerView

  1. 导包

    dependencies{
        implementation 'androidx.recyclerview:recyclerview:1.1.0'
    }
    

在这里插入图片描述

activity_main.xml

<?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">

    <androidx.recyclerview.widget.RecyclerView
        android:id="@+id/rv"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>

</LinearLayout>

recycler_item.xml

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

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

</LinearLayout>

Bean.java

package com.tinno.my_recyclerview;

public class Bean {

    String name;

    public String getName() {
        return name;
    }

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

MyAdapter.java

package com.tinno.my_recyclerview;

import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;

import java.util.List;

public class MyAdapter extends RecyclerView.Adapter<MyAdapter.MyViewHolder>{

    private List<Bean> data;
    private Context context;

    public MyAdapter(List<Bean> data, Context context) {
        this.data = data;
        this.context = context;
    }

    @NonNull
    @Override
    public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        //先拿到 recycler_item 的布局
        View view = View.inflate(context, R.layout.recycler_item, null);
        return new MyViewHolder(view);
    }

    @Override
    public void onBindViewHolder(@NonNull MyViewHolder holder, int position) {
        //绑定数据
        holder.tv.setText(data.get(position).getName());
    }

    @Override
    public int getItemCount() {
        return data == null ? 0 : data.size();
    }

    // MyViewHolder 需要继承 RecyclerView.ViewHolder
    public class MyViewHolder extends RecyclerView.ViewHolder {
        private TextView tv;

        public MyViewHolder(@NonNull View itemView) {
            super(itemView);
            tv = itemView.findViewById(R.id.tv);

            // 进行自定义监听方法的实现
            itemView.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    if(mOnItemClickListener != null){
                        mOnItemClickListener.onRecyclerItemClick(getAbsoluteAdapterPosition());
                    }
                }
            });
        }
    }

    private OnRecyclerItemClickListener mOnItemClickListener;

    //设置监听的方法
    public void setRecyclerItemClickListener(OnRecyclerItemClickListener listener){
        mOnItemClickListener = listener;
    }

    //自定义设置一个监听器
    public interface OnRecyclerItemClickListener{
        void onRecyclerItemClick(int position);
    }
}

MainActivity.java

package com.tinno.my_recyclerview;

import androidx.appcompat.app.AppCompatActivity;
import androidx.recyclerview.widget.GridLayoutManager;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import androidx.recyclerview.widget.StaggeredGridLayoutManager;

import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.LinearLayout;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends AppCompatActivity {

    private List<Bean> data = new ArrayList<>();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        for (int i = 0; i < 20000; i++) {
            if (i % 4 != 0 ){
                continue;
            }
            Bean bean = new Bean();
            bean.setName("享受" + i);
            data.add(bean);
        }

        RecyclerView recyclerView = findViewById(R.id.rv);

        //为recyclerView进行一个布局,LinearLayout布局
        /*LinearLayoutManager linearLayoutManager = new LinearLayoutManager(this);
        recyclerView.setLayoutManager(linearLayoutManager);*/

        //网格显示,一行显示3个
        GridLayoutManager gridLayoutManager = new GridLayoutManager(this,3);
        recyclerView.setLayoutManager(gridLayoutManager);

        // 瀑布流布局 显示
        /*StaggeredGridLayoutManager staggeredGridLayoutManager = new StaggeredGridLayoutManager(4, LinearLayout.VERTICAL);
        recyclerView.setLayoutManager(staggeredGridLayoutManager);*/

        MyAdapter myAdapter = new MyAdapter(data, this);
        recyclerView.setAdapter(myAdapter);
	
        //实现点击方法
        myAdapter.setRecyclerItemClickListener(new MyAdapter.OnRecyclerItemClickListener() {
            @Override
            public void onRecyclerItemClick(int position) {
                Log.e("tinno", "onRecyclerItemClick: " + position );
            }
        });
    }
}

在这里插入图片描述

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

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/31 18:06:29-

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