【移动开发学习】 Android Studio 编写一个简单的微信界面 (2)

这篇具有很好参考价值的文章主要介绍了【移动开发学习】 Android Studio 编写一个简单的微信界面 (2)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Android Studio简单还原微信ui

上一期完成内容(前情提要)
  上次我们简单地实现了微信的几个初始界面,并且在联系人页面通过recycleview添加了许多的view
目标
  建立在上次的基础上,我们来扩展联系人界面的功能,给每一个view添加一个点击功能,让其可以跳转到另一个activity,来显示联系人详细信息
技术需求
  activity, xml, fragment, recyclerview
成果展示
  联系人列表中的每一项都可以点击,并跳转到对应联系人的详细页
  

【移动开发学习】 Android Studio 编写一个简单的微信界面 (2)       【移动开发学习】 Android Studio 编写一个简单的微信界面 (2)       【移动开发学习】 Android Studio 编写一个简单的微信界面 (2)

仓库地址
https://github.com/SmileEX/wecaht.git
 

实现过程
在 onBindViewHolder 中添加 onClick 函数
首先我们要在之前编写的 RecycleViewAdapter 中添加额外的代码逻辑,让我们的每一个item具有点击功能,我们在 onBindViewHolder 中添加onClick函数。
 1 @Override
 2     public void onBindViewHolder(@NonNull Myviewholder holder, int position) {
 3         holder.tvimg.setImageResource(mSrc.get(position));
 4         holder.tvContent.setText(mList.get(position));
 5         final int itemPosition = position;
 6         holder.itemView.setOnClickListener(new View.OnClickListener() {
 7             @Override
 8             public void onClick(View v) {
 9                 String selectedItem = mList.get(itemPosition);
10                 Toast.makeText(v.getContext(), "Clicked: " + selectedItem, Toast.LENGTH_SHORT).show();
11                 //跳转
12                 Intent intent = new Intent(context, FriendDetailsActivity.class);
13                 //传输信息给跳转的activity,以便在新的activity中显示被点击item对应的内容
14                 intent.putExtra("name", mList.get(itemPosition));
15                 intent.putExtra("avatar", mSrc.get(itemPosition));
16                 context.startActivity(intent);
17             }
18         });
19     }

当用户点击一个item时,会先在屏幕底部弹出提示 “Clicked:被点击id”, 然后再跳转到新的页面,这个页面是用来显示联系人详情的,我们通过 Intent 去传递信息来让新的 activity 显示对应的内容。


 

设计跳转 activity

简单编写一个联系人详情页,可以显示这个联系人的头像,id,以及地区等信息,其中头像和id可以根据item的信息而变化,地区和微信号的显示暂时只是静态的

编写完后的预览大概这个样子

【移动开发学习】 Android Studio 编写一个简单的微信界面 (2)

 以下时xml文件内容

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
 3     xmlns:app="http://schemas.android.com/apk/res-auto"
 4     xmlns:tools="http://schemas.android.com/tools"
 5     android:layout_width="match_parent"
 6     android:layout_height="match_parent"
 7     tools:context=".FriendDetailsActivity">
 8 
 9     <ImageView
10         android:id="@+id/avatar"
11         android:layout_width="100dp"
12         android:layout_height="100dp"
13         android:textSize="30sp"
14         app:layout_constraintStart_toStartOf="parent"
15         app:layout_constraintTop_toBottomOf="@+id/friendDetail" />
16 
17     <TextView
18         android:id="@+id/friendDetail"
19         android:layout_width="0dp"
20         android:layout_height="wrap_content"
21         android:text="这是联系人详情页"
22         android:textAlignment="center"
23         android:textColor="#2196F3"
24         android:textSize="30sp"
25         app:layout_constraintEnd_toEndOf="parent"
26         app:layout_constraintHorizontal_bias="0.0"
27         app:layout_constraintStart_toStartOf="parent"
28         app:layout_constraintTop_toTopOf="parent" />
29 
30     <TextView
31         android:id="@+id/information"
32         android:layout_width="wrap_content"
33         android:layout_height="wrap_content"
34         android:text="TextView"
35         android:textSize="30sp"
36         android:textStyle="bold"
37         app:layout_constraintStart_toEndOf="@+id/avatar"
38         app:layout_constraintTop_toBottomOf="@+id/friendDetail" />
39 
40     <TextView
41         android:id="@+id/wechatid"
42         android:layout_width="wrap_content"
43         android:layout_height="wrap_content"
44         android:text="微信号:xxxxx"
45         android:textSize="15sp"
46         app:layout_constraintStart_toEndOf="@+id/avatar"
47         app:layout_constraintTop_toBottomOf="@+id/information" />
48 
49     <TextView
50         android:id="@+id/area"
51         android:layout_width="wrap_content"
52         android:layout_height="wrap_content"
53         android:text="地区:中国"
54         android:textSize="15sp"
55         app:layout_constraintStart_toEndOf="@+id/avatar"
56         app:layout_constraintTop_toBottomOf="@+id/wechatid" />
57 
58     <Button
59         android:id="@+id/send"
60         android:layout_width="0dp"
61         android:layout_height="wrap_content"
62         android:text="发消息(todo)"
63         app:layout_constraintBottom_toBottomOf="parent"
64         app:layout_constraintEnd_toEndOf="parent"
65         app:layout_constraintStart_toStartOf="parent" />
66 
67 </androidx.constraintlayout.widget.ConstraintLayout>

最后再来编写一下联系人详情页的activity的java文件

 1 public class FriendDetailsActivity extends AppCompatActivity {
 2 
 3     @Override
 4     protected void onCreate(Bundle savedInstanceState) {
 5         super.onCreate(savedInstanceState);
 6         setContentView(R.layout.activity_friend_details);
 7         
 8         //接受Adapter传输过来的信息
 9         Intent intent = getIntent();
10         //第一个是联系人id信息
11         String string = intent.getStringExtra("name");
12         //第二个是联系人头像信息
13         int avatar = intent.getIntExtra("avatar", 0);
14         //然后再给对应的view设置对应信息的路径
15         TextView textview = findViewById(R.id.information);
16         textview.setText(string);
17         ImageView imageview = findViewById(R.id.avatar);
18         imageview.setImageResource(avatar);
19     }
20 }

通过getIntent函数我们接受来自item传送过来的id和头像信息,然后再给对应view设置对应的id和图片资源路径

getIntExtra()函数的第二个参数是默认是,也就是如果未能从Intent获取关于头像路径的信息就会默认填入,所以可以设置一个默认值来避免头像显示空白

 

仓库链接

https://github.com/SmileEX/wecaht.git文章来源地址https://www.toymoban.com/news/detail-746058.html

到了这里,关于【移动开发学习】 Android Studio 编写一个简单的微信界面 (2)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Android studio学习感受加一个简单的登录注册

    作为一名使用Android Studio的学生,我也深有同感。在我看来,Android Studio是一款非常出色的开发工具先得感觉是Android Studio+Genymotion的组合比以前好用太多了。以前我记得eclipse要加各种jar包,文件夹也混乱的很。 然后是关于Activity和布局、控件,感觉跟网页前端很像,布局和控

    2024年02月02日
    浏览(17)
  • Android studio 编写一个登录页面,并且具有注册功能

    1、创建登录界面,点击注册按钮,弹出注册窗口。 2、创建注册窗口,输入用户名和密码,在SQLite中存储用户名和密码。 3、注册成功,跳转到登录界面,进行登录。 4、注册成功,把用户名和密码保存到SharedPreferences中,登录时自动填充用户名和密码。           登录页

    2023年04月08日
    浏览(20)
  • 用Android Studio编写一个登录界面和注册界面并可以跳转

    下面是使用 Android Studio 编写一个简单的登录界面和注册界面,并实现跳转的示例代码。 首先,在 res/layout 目录下创建一个名为 activity_login.xml 的布局文件,作为登录界面的布局: 接下来,在 res/layout 目录下创建一个名为 activity_register.xml 的布局文件,作为注册界面的布局:

    2024年04月09日
    浏览(55)
  • Visual Studio 2019 C# 上位机入门(1):如何创建工程编写一个简单应用

    Visual Studio 2019下载安装步骤可以看:https://blog.csdn.net/weixin_44788542/article/details/114271126 这里不赘述,默认电脑上已经安装好了。 1、打开安装好的Visual Studio后,选择创建新项目。 2、找到选择C#下面的Windows 窗体应用,然后下一步起名和文件存放位置 如果找不到Windows 窗体应用,

    2024年02月05日
    浏览(28)
  • 移动应用开发环境搭建Android Studio

    记得提前开启电脑虚拟化支持,具体方法可自行百度 查看是否启用虚拟化 JDK安装与卸载 由于Andriod开发使用的语言是javaKotlin,这里使用的是java语言所以需要先安装java的开发环境 所有开发 Android 应用程序需要的工具都是开源的,并且可以从互联网上下载 Android Studio 是谷歌推

    2023年04月08日
    浏览(25)
  • 移动开发项目 Android Studio 健康助手APP

    健康助手系统是一款便捷软件,旨在通过提供多方面的的健康便捷的管理服务,让用户的生活更健康,更便捷。用户可以在健康助手APP上购买不同的体检套餐,预约医生,使用地图查找药房等的位置,浏览网页了解健康知识,传播健康文化。 (1)为了更好地了解自己的身体

    2024年02月03日
    浏览(34)
  • 基于android studio开发的火车票购票系统app,android移动开发课设,毕业设计

    基于android studio开发实现火车票购票系统app 适用于android移动开发学习项目,课程设计,毕业设计等 开发工具:android studio 或者intellij idea专业版 操作系统:windows10 java: JDK11 构建工具Gradle : gradle-7.0.0 模拟器AVD:pixel 3XL API 30 具体AVD配置详情如下 APP功能 该APP包含17个Activity,每

    2024年02月09日
    浏览(14)
  • Android Studio制作一个简单的计算器APP

    虽然现在我们日常生活中很少用到计算器,但是第一次尝试在Android Studio上做一个计算器 程序设计步骤: (1)在布局文件中声明编辑文件框EditText,按钮Button等组件。 (2)在MainActivity中获取组件实例。 (3)通过swtich函数,判断输入的内容,并进行相应操作,通过getText()获

    2024年02月11日
    浏览(15)
  • 《Android 移动应用基础教程(Android Studio)(第2版)》【学习笔记】【2023春】【附源码】

    《Android 移动应用基础教程(Android Studio)(第2版)》黑马程序员 源代码 Android——六大基本布局总结/CSDN@小马 同学 【Android】线性布局(LinearLayout)最全解析/CSDN@Teacher.Hu 一个不错的计算器界面👇 Android Studio App LinearLayout多层布局嵌套/CSDN@pythontojava 一个简单的布局👇 Andro

    2024年02月01日
    浏览(20)
  • Android Studio|使用SqLite实现一个简单的登录注册功能

    本学期学习了Android Studio这门课程,本次使用Android Studio自带的sqlite数据库实现一个简单的登录注册功能。 目录 一、了解什么是Android Studio? 二、了解什么是sqlite? 三、创建项目文件  四、创建活动文件和布局文件。 五、创建数据库,连接数据库  六、创建实体类,实现注

    2024年02月06日
    浏览(21)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包