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

[移动开发]移动开发第二次作业

实现方案/核心技术

在实验二的adapter和RecycleView的使用基础上,对有recycleView的页面的项目进行点击跳转设计

功能说明

在实验二中,我在CALL界面添加了recycleView组件,实现了类似通讯录的界面,且添加了点击效果,当点击recycleView的item的头像时,效果为查询联系人,当点击recycleView的item的名称时效果为拨号呼叫该联系人。在此基础上,我新添加了一个呼叫中的活动

,当点击recycleView的item的名称时
会跳转至呼叫活动界面。

跳转目标界面活动以及布局代码及布局效果展示

活动代码:

//  MainActivity2.java
package com.example.homework;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;

public class MainActivity2 extends AppCompatActivity {

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

布局代码及效果:

//  MainActivity2.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=".MainActivity2">

    <ImageView
        android:id="@+id/imageView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:srcCompat="@drawable/calling"
        tools:layout_editor_absoluteY="178dp"
        tools:ignore="MissingConstraints" />

    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textSize="30dp"
        android:textColor="@color/green"
        android:text="通话中"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/imageView"
        tools:ignore="MissingConstraints" />
</androidx.constraintlayout.widget.ConstraintLayout>

布局效果:
在这里插入图片描述

跳转功能核心代码

在原有的点击效果上,增加点击点击跳转功能。
下面展示一些 内联代码片

// ItemAdapter.java
package com.example.homework;

import android.content.Context;
import android.content.Intent;
import android.media.Image;
import android.telecom.Call;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.fragment.app.Fragment;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import android.content.ClipData;
import android.os.Bundle;
import android.view.MenuItem;
import android.widget.Switch;
import com.google.android.material.bottomnavigation.BottomNavigationView;
import android.widget.LinearLayout;
import java.util.ArrayList;

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

import java.util.ArrayList;

public class ItemAdapter  extends  RecyclerView.Adapter<ItemAdapter.ViewHolder> {
    public Context context;

    private ArrayList<CallItem> al_items;

    public ItemAdapter(ArrayList<CallItem> al_items,Context context) {
        this.al_items = al_items;
        this.context =context;
    }

    static class ViewHolder extends RecyclerView.ViewHolder {

        View itemView;
        ImageView item_image;
        TextView item_name;



        public ViewHolder(@NonNull View itemView) {
            super(itemView);
            this.itemView=itemView;
            item_image =  itemView.findViewById(R.id.item_image);
            item_name = itemView.findViewById(R.id.item_name);
        }
    }

    @NonNull
    @Override
    public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.call_fragment, parent, false);
     final  ViewHolder holder = new ViewHolder(view);


      holder.itemView.setOnClickListener(new View.OnClickListener() {
          @Override
          public void onClick(View view) {
              Intent intent1 = new Intent(context,MainActivity2.class);
              context.startActivity(intent1);
              int position = holder.getAdapterPosition();
              CallItem item =al_items.get(position);
              Toast.makeText(view.getContext(), "正在呼叫联系人:"+item.getItem_named(), Toast.LENGTH_SHORT).show();
              


          }
      });
        holder.item_image.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                int position = holder.getAdapterPosition();
                CallItem item =al_items.get(position);
                Toast.makeText(view.getContext(), "查看联系人:"+item.getItem_named(), Toast.LENGTH_SHORT).show();
            }
        });

        return holder;
    }

    @Override
    public void onBindViewHolder(@NonNull ViewHolder holder, int position) {
        CallItem item = al_items.get(position);
        holder.item_name.setText(item.getItem_named());/*holder.itemText.setText(data.get(position).getMeg()); ,m*/
                                                // meg->name  group->item
        holder.item_image.setImageResource(item.getItem_imageId());


    }

    @Override
    public int getItemCount() {


        return al_items.size();
    }


}

效果展示:

第二次作业效果演示

代码仓地址

GITEE代码仓查看项目全部源代码和资源文件

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2021-10-27 12:56:47  更:2021-10-27 12:58:25 
 
开发: 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年11日历 -2024/11/24 1:14:11-

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