【移動開發學習】 Android Studio 編寫一個簡單的微信界面 (2)

来源:https://www.cnblogs.com/smileex/archive/2023/11/12/AndroidStudy02.html
-Advertisement-
Play Games

Android Studio簡單還原微信ui 上一期完成內容(前情提要) 上次我們簡單地實現了微信的幾個初始界面,並且在聯繫人頁面通過recycleview添加了許多的view 目標 建立在上次的基礎上,我們來擴展聯繫人界面的功能,給每一個view添加一個點擊功能,讓其可以跳轉到另一個activit ...


Android Studio簡單還原微信ui
上一期完成內容(前情提要)   上次我們簡單地實現了微信的幾個初始界面,並且在聯繫人頁面通過recycleview添加了許多的view 目標   建立在上次的基礎上,我們來擴展聯繫人界面的功能,給每一個view添加一個點擊功能,讓其可以跳轉到另一個activity,來顯示聯繫人詳細信息 技術需求   activity, xml, fragment, recyclerview 成果展示   聯繫人列表中的每一項都可以點擊,並跳轉到對應聯繫人的詳細頁
  

              

倉庫地址 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的信息而變化,地區和微信號的顯示暫時只是靜態的

編寫完後的預覽大概這個樣子

 以下時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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 使用 ORDER BY 進行排序 使用 ORDER BY 語句按升序或降序對結果進行排序。 ORDER BY 關鍵字預設按升序排序。要按降序排序結果,使用 DESC 關鍵字。 示例按名稱按字母順序排序結果: import mysql.connector mydb = mysql.connector. ...
  • 1. pip命令 查看已安裝的包 pip list 安裝包 pip install package_name 卸載包 # 卸載指定包 pip uninstall package_name # 卸載已安裝的所有第三方Python庫 pip freeze > list.txt pip uninstall ...
  • 危機感 距離上一次找工作面試已經過去快2年了,那時候正值疫情肆虐,雖然還未感受到“寒潮來臨”的苗頭,但最終還是成功通過了幾輪面試,順利簽約。在目前公司待了2年了,在大環境的影響下,沒有加薪、沒有年終(這個真的很傷)、各種項目混亂、技術快停滯不前,年末又要過一年了,又離35進一步了,終危機感又來了,不 ...
  • 寫在前面 就在這周三,無意間我在掘金刷到一篇文章,讓我這個35歲的單身老狗又次相信了愛情,而且相信真的會有那種所謂的緣分和相濡以沫、雙向奔赴的愛情。 我又相信了愛情 文中男主是在掘金相親角成功的找到了另一半,而順利結婚,打動我的應該是女主的真誠吧,或許應該說那應該是我最嚮往的愛情,如下文中描述: 簡 ...
  • 在Go語言中,我們通常會遇到兩種主要的方式來處理和操作字元串:使用fmt.Sprintf函數和string.Builder類型。儘管兩者都可以實現字元串的格式化和連接,但它們在性能和用法上有一些關鍵區別。 1. fmt.Sprintf fmt.Sprintf是一個函數,它根據提供的格式化字元串和參數 ...
  • 在多線程編程中,如果每個線程的運行不是完全獨立的。那麼,一個線程執行到某個時刻需要知道其他線程發生了什麼。嗯,這就是所謂線程同步。同步事件對象(XXXEvent)有兩種行為: 1、等待。線程在此時會暫停運行,等待其他線程發出信號才繼續(等你約); 2、發出信號。當前線程發出信號,其他正在等待線程收到 ...
  • 思想 DAO(Data Access Object)數據訪問對象,是我們在做結構化資料庫訪問的時候傳輸的對象,通過這個對象我們可以與資料庫中的表建立映射關係 DTO(Data Transfer Object)是我們在與前端進行數據交換時傳遞的對象 為什麼需要設置這這兩種對象呢? 為了數據安全 如果我 ...
  • 1、Bring Up流程 SOC (System on a Chip) bring-up是一個複雜的過程,涉及到硬體、固件和軟體的集成和驗證,以下是一個基於BROM,SPL,UBOOT和Linux的啟動流程的概述: BROM (Boot Read-Only Memory)啟動:啟動的最初階段,在這個 ...
一周排行
    -Advertisement-
    Play Games
  • 當使用Autofac處理一個介面有多個實現的情況時,通常會使用鍵(key)進行區分或者通過IIndex索引註入,也可以通過IEnumerable集合獲取所有實例,以下是一個具體的例子,演示如何在Autofac中註冊多個實現,並通過構造函數註入獲取指定實現。 首先,確保你已經安裝了Autofac Nu ...
  • 本篇將分享Prometheus+Grafana的監控平臺搭建,並監控之前文章所搭建的主機&服務,分享日常使用的一些使用經驗本篇將配置常用服務的監控與面板配置:包括 MySQL,MongoDB,CLickHouse,Redis,RabbitMQ,Linux,Windows,Nginx,站點訪問監控,已... ...
  • 使用Aspirate可以將Aspire程式部署到Kubernetes 集群 工具安裝 dotnet tool install -g aspirate --prerelease 註意:Aspirate 正在開發中,該軟體包將作為預覽版進行版本控制,--prelease 選項將獲得最新的預覽版。 容器註 ...
  • 前言 本文要說的這種開發模式,這種模式並不是只有blazor支持,js中有一樣的方案next.js nuxt.js;blazor還有很多其它內容,本文近關註漸進式開發模式。 是的,前後端是主流,不過以下情況也許前後端分離並不是最好的選擇: 小公司,人員不多,利潤不高,創業階段能省則省 個人開發者,接 ...
  • 在.NET中,Microsoft.Extensions.Logging是一個靈活的日誌庫,它允許你將日誌信息記錄到各種不同的目標,包括資料庫。在這個示例中,我將詳細介紹如何使用Microsoft.Extensions.Logging將日誌保存到MySQL資料庫。我們將使用Entity Framewo ...
  • chatgpt介面開發筆記3: 語音識別介面 1.文本轉語音 1、瞭解介面參數 介面地址: POST https://api.openai.com/v1/audio/speech 下麵是介面文檔描述內容: 參數: { "model": "tts-1", "input": "你好,我是饒坤,我是ter ...
  • 前面兩篇文章主要是介紹瞭如何解決高併發情況下資源爭奪的問題。但是現實的應用場景中除了要解決資源爭奪問題,高併發的情況還需要解決更多問題,比如快速處理業務數據等, 本篇文章簡要羅列一下與之相關的更多技術細節。 1、非同步編程:使用async和await關鍵字進行非同步編程,這可以避免阻塞線程,提高程式的響 ...
  • 大家好,我是棧長。 Nacos 2.3.0 前幾天正式發佈了,新增了不少實用性的新功能,真是史上最強版本。 Nacos 2.3.0 還真是一個比較重要的大版本,因為它涉及了太多重大更新,今天棧長給大家來解讀下。 Nacos 先掃個盲: Nacos 一個用於構建雲原生應用的動態服務發現、配置管理和服務 ...
  • IDEA的遠程開發功能,可以將本地的編譯、構建、調試、運行等工作都放在遠程伺服器上執行,而本地僅運行客戶端軟體進行常規的開發操作即可,舊版本IDEA目前不支持該功能.,本例使用的是IDEA2023.2.5版本 下麵介紹如何在IDEA中設置遠程連接伺服器開發環境並結合Cpolar內網穿透工具實現無公網 ...
  • 本文解釋為啥會有響應式編程,為什麼它在開發者中不太受歡迎,以及引入 Java 虛擬線程後它可能最終會消失。 命令式風格編程一直深受開發者喜愛,如 if-then-else、while 迴圈、函數和代碼塊等結構使代碼易理解、調試,異常易追蹤。然而,像所有好的東西一樣,通常也有問題。這種編程風格導致線程 ...