日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

android 仿微信demo——微信主界面實現(xiàn)

瀏覽:256日期:2022-06-03 18:20:08
目錄主界面實現(xiàn)測試總結

以往文章中實現(xiàn)微信啟動頁,登錄注冊功能,此基礎上繼續(xù)完善仿微信功能。

主界面實現(xiàn)

(1)整體采用RelativeLayout相對布局

(2)最上面是toolbar操作欄,搜索框SearchView,Overflow(含有4個單選菜單項)

(3)中間使用Fragment組件(不使用ViewPager,有興趣可以自己添加實現(xiàn)下)。

(4)最下面是水平的LinearLayout線性布局:含有4個自定義的控件

android 仿微信demo——微信主界面實現(xiàn)

這一篇主要是實現(xiàn)主界面,其他像頂部(toolbar,SearchView,Overflow),中間的fragment,后續(xù)文章在更新。

創(chuàng)建主界面activity MainWeixin.java

MainWeixin.java

package com.example.wxchatdemo;import android.annotation.SuppressLint;import android.app.AlertDialog;import android.app.Dialog;import android.app.FragmentManager;import android.app.FragmentTransaction;import android.content.DialogInterface;import android.content.Intent;import android.graphics.Color;import android.os.Bundle;import android.support.v4.app.FragmentActivity;import android.view.KeyEvent;import android.view.View;import android.view.Window;import android.widget.ImageView;import android.widget.TextView;public class MainWeixin extends FragmentActivity implements View.OnClickListener { private WeixinFragment firstFragment = null;// 用于顯示微信界面 private ContactListFragment secondFragment = null;// 用于顯示通訊錄界面 private FindFragment thirdFragment = null;// 用于顯示發(fā)現(xiàn)界面 private SelfFragment fourthFragment = null;// 用于顯示我界面 private View firstLayout = null;// 微信顯示布局 private View secondLayout = null;// 通訊錄顯示布局 private View thirdLayout = null;// 發(fā)現(xiàn)顯示布局 private View fourthLayout = null;// 我顯示布局 /*聲明組件變量*/ private ImageView weixinImg = null; private ImageView contactImg = null; private ImageView findImg = null; private ImageView selfImg = null; private TextView weixinText = null; private TextView contactText = null; private TextView findText = null; private TextView selfText = null; private FragmentManager fragmentManager = null;// 用于對Fragment進行管理 @Override protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);requestWindowFeature(Window.FEATURE_NO_TITLE);//要求窗口沒有titlesuper.setContentView(R.layout.main_weixin);// 初始化布局元素initViews();fragmentManager = getFragmentManager();//用于對Fragment進行管理// 設置默認的顯示界面setTabSelection(0); } /** * 在這里面獲取到每個需要用到的控件的實例,并給它們設置好必要的點擊事件 */ @SuppressLint('NewApi') public void initViews() {fragmentManager = getFragmentManager();firstLayout = findViewById(R.id.weixin_layout);secondLayout = findViewById(R.id.contacts_layout);thirdLayout = findViewById(R.id.find_layout);fourthLayout = findViewById(R.id.self_layout);weixinImg = (ImageView) findViewById(R.id.weixin_img);contactImg = (ImageView) findViewById(R.id.contact_img);findImg = (ImageView) findViewById(R.id.find_img);selfImg = (ImageView) findViewById(R.id.self_img);weixinText = (TextView) findViewById(R.id.weixin_text);contactText = (TextView) findViewById(R.id.contact_text);findText = (TextView) findViewById(R.id.find_text);selfText = (TextView) findViewById(R.id.self_text);//處理點擊事件firstLayout.setOnClickListener(this);secondLayout.setOnClickListener(this);thirdLayout.setOnClickListener(this);fourthLayout.setOnClickListener(this); } @Override public void onClick(View v) {switch (v.getId()) { case R.id.weixin_layout:setTabSelection(0);// 當點擊了微信時,選中第1個tabbreak; case R.id.contacts_layout:setTabSelection(1);// 當點擊了通訊錄時,選中第2個tabbreak; case R.id.find_layout:setTabSelection(2);// 當點擊了發(fā)現(xiàn)時,選中第3個tabbreak; case R.id.self_layout:setTabSelection(3);// 當點擊了我時,選中第4個tabbreak; default:break;} } /** * 根據(jù)傳入的index參數(shù)來設置選中的tab頁 每個tab頁對應的下標。0表示微信,1表示通訊錄,2表示發(fā)現(xiàn),3表示我 */ @SuppressLint('NewApi') private void setTabSelection(int index) {clearSelection();// 每次選中之前先清除掉上次的選中狀態(tài)FragmentTransaction transaction = fragmentManager.beginTransaction();// 開啟一個Fragment事務hideFragments(transaction);// 先隱藏掉所有的Fragment,以防止有多個Fragment顯示在界面上的情況switch (index) { case 0:// 當點擊了我的微信tab時改變控件的圖片和文字顏色weixinImg.setImageResource(R.drawable.tab_weixin_pressed);//修改布局中的圖片weixinText.setTextColor(Color.parseColor('#0090ff'));//修改字體顏色if (firstFragment == null) { /*獲取登錄activity傳過來的微信號*/ Intent intent = getIntent(); String number = intent.getStringExtra('weixin_number'); // 如果FirstFragment為空,則創(chuàng)建一個并添加到界面上 firstFragment = new WeixinFragment(number); transaction.add(R.id.fragment, firstFragment);} else { // 如果FirstFragment不為空,則直接將它顯示出來 transaction.show(firstFragment);//顯示的動作}break; // 以下和firstFragment類同 case 1:contactImg.setImageResource(R.drawable.tab_address_pressed);contactText.setTextColor(Color.parseColor('#0090ff'));if (secondFragment == null) { /*獲取登錄activity傳過來的微信號*/ Intent intent = getIntent(); String number = intent.getStringExtra('weixin_number'); secondFragment = new ContactListFragment(number); transaction.add(R.id.fragment, secondFragment);} else { transaction.show(secondFragment);}break; case 2:findImg.setImageResource(R.drawable.tab_find_frd_pressed);findText.setTextColor(Color.parseColor('#0090ff'));if (thirdFragment == null) { thirdFragment = new FindFragment(); transaction.add(R.id.fragment, thirdFragment);} else { transaction.show(thirdFragment);}break; case 3:selfImg.setImageResource(R.drawable.tab_settings_pressed);selfText.setTextColor(Color.parseColor('#0090ff'));if (fourthFragment == null) { fourthFragment = new SelfFragment(); transaction.add(R.id.fragment, fourthFragment);} else { transaction.show(fourthFragment);}break;}transaction.commit(); } /** * 清除掉所有的選中狀態(tài) */ private void clearSelection() {weixinImg.setImageResource(R.drawable.tab_weixin_normal);weixinText.setTextColor(Color.parseColor('#82858b'));contactImg.setImageResource(R.drawable.tab_address_normal);contactText.setTextColor(Color.parseColor('#82858b'));findImg.setImageResource(R.drawable.tab_find_frd_normal);findText.setTextColor(Color.parseColor('#82858b'));selfImg.setImageResource(R.drawable.tab_settings_normal);selfText.setTextColor(Color.parseColor('#82858b')); } /** * 將所有的Fragment都設置為隱藏狀態(tài) 用于對Fragment執(zhí)行操作的事務 */ @SuppressLint('NewApi') private void hideFragments(FragmentTransaction transaction) {if (firstFragment != null) { transaction.hide(firstFragment);}if (secondFragment != null) { transaction.hide(secondFragment);}if (thirdFragment != null) { transaction.hide(thirdFragment);}if (fourthFragment != null) { transaction.hide(fourthFragment);} } //封裝一個AlertDialog private void exitDialog() {Dialog dialog = new AlertDialog.Builder(this).setTitle('溫馨提示').setMessage('您確定要退出程序嗎?').setPositiveButton('關閉微信', new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface arg0, int arg1) {finish(); }}).setNegativeButton('取消', new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface arg0, int arg1) { }}).create();dialog.show();//顯示對話框 } /** * 返回菜單鍵監(jiān)聽事件 */ @Override public boolean onKeyDown(int keyCode, KeyEvent event) {if (keyCode == KeyEvent.KEYCODE_BACK) {//如果是返回按鈕 exitDialog();}return super.onKeyDown(keyCode, event); }}

創(chuàng)建主界面activity MainWeixin.java對應的主布局文件main_weixin.xml

main_weixin.xml

<RelativeLayout xmlns:android='http://schemas.android.com/apk/res/android' android:layout_width='match_parent' android:layout_height='match_parent'> <FrameLayoutandroid: android:layout_width='match_parent'android:layout_height='match_parent'android:background='@color/white'> </FrameLayout> <LinearLayoutandroid:layout_width='match_parent'android:layout_height='48dp'android:layout_alignParentStart='true'android:layout_alignParentLeft='true'android:layout_alignParentBottom='true'android:background='#f7f7f7'android:gravity='center'android:orientation='horizontal'><LinearLayout android: android:layout_width='0dp' android:layout_height='match_parent' android:layout_centerVertical='true' android:layout_weight='1' android:orientation='vertical' android:padding='3dp'> <ImageViewandroid: android:layout_width='wrap_content'android:layout_height='24dp'android:layout_gravity='center_horizontal'android:src='http://m.b3g6.com/bcjs/@drawable/tab_weixin_pressed' /> <TextViewandroid: android:layout_width='wrap_content'android:layout_height='20dp'android:layout_gravity='center_horizontal'android:gravity='top'android:text='微信'android:textColor='#82858b'android:textSize='13dp' /></LinearLayout><LinearLayout android: android:layout_width='0dp' android:layout_height='match_parent' android:layout_centerVertical='true' android:layout_weight='1' android:orientation='vertical' android:padding='3dp'> <ImageViewandroid: android:layout_width='wrap_content'android:layout_height='24dp'android:layout_gravity='center_horizontal'android:src='http://m.b3g6.com/bcjs/@drawable/tab_address_normal' /> <TextViewandroid: android:layout_width='wrap_content'android:layout_height='20dp'android:layout_gravity='center_horizontal'android:gravity='top'android:text='通訊錄'android:textColor='#82858b'android:textSize='13dp' /></LinearLayout><LinearLayout android: android:layout_width='0dp' android:layout_height='match_parent' android:layout_centerVertical='true' android:layout_weight='1' android:orientation='vertical' android:padding='3dp'> <ImageViewandroid: android:layout_width='wrap_content'android:layout_height='24dp'android:layout_gravity='center_horizontal'android:src='http://m.b3g6.com/bcjs/@drawable/tab_find_frd_normal' /> <TextViewandroid: android:layout_width='wrap_content'android:layout_height='20dp'android:layout_gravity='center_horizontal'android:gravity='top'android:text='發(fā)現(xiàn)'android:textColor='#82858b'android:textSize='13dp' /></LinearLayout><LinearLayout android: android:layout_width='0dp' android:layout_height='match_parent' android:layout_centerVertical='true' android:layout_weight='1' android:orientation='vertical' android:padding='3dp'> <ImageViewandroid: android:layout_width='wrap_content'android:layout_height='24dp'android:layout_gravity='center_horizontal'android:src='http://m.b3g6.com/bcjs/@drawable/tab_settings_normal' /> <TextViewandroid: android:layout_width='wrap_content'android:layout_height='20dp'android:layout_gravity='center_horizontal'android:gravity='top'android:text='我'android:textColor='#82858b'android:textSize='13dp' /></LinearLayout> </LinearLayout></RelativeLayout>

創(chuàng)建4個Fragment.class和4個Fragment.xml布局,對應微信,通訊錄,發(fā)現(xiàn),我

WeixinFragment.java

package com.example.wxchatdemo;import android.annotation.SuppressLint;import android.app.Fragment;import android.os.Bundle;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;@SuppressLint('ValidFragment')public class WeixinFragment extends Fragment { private String number; @SuppressLint('ValidFragment') WeixinFragment(String number) {this.number = number; } public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {View view = inflater.inflate(R.layout.weixin_fragment, container, false);return view; }}

ContactListFragment.java

package com.example.wxchatdemo;import android.annotation.SuppressLint;import android.app.Fragment;import android.os.Bundle;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;@SuppressLint('ValidFragment')public class ContactListFragment extends Fragment { private String number; @SuppressLint('ValidFragment') ContactListFragment(String number) {this.number = number; } public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {View view = inflater.inflate(R.layout.weixin_fragment, container, false);return view; }}

FindFragment.java

package com.example.wxchatdemo;import android.app.Fragment;import android.os.Bundle;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;public class FindFragment extends Fragment { public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {View view = inflater.inflate(R.layout.find_fragment, container, false);return view; }}

SelfFragment.java

package com.example.wxchatdemo;import android.app.Fragment;import android.os.Bundle;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;public class SelfFragment extends Fragment { public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {View view = inflater.inflate(R.layout.self_fragment, container, false);return view; }}

創(chuàng)建四個fragmen布局,代碼都一樣,只要有就行,后面會完善的,四個fragment布局文件為,weixin_fragment.xml,contactlist_fragment.xml,find_fragment.xml,self_fragment.xml

<LinearLayout xmlns:android='http://schemas.android.com/apk/res/android' android:layout_width='match_parent' android:layout_height='match_parent'></LinearLayout>

在AndroidMainfest.xml中聲明創(chuàng)建的activity,由于創(chuàng)建fragment不是activity,所有不用聲明,聲明主界面的activity即可(fragment是內嵌在activity中的)

android 仿微信demo——微信主界面實現(xiàn)

測試

把之前兩個登錄activity請求成功跳轉的activity代碼段注釋取消掉,啟動項目測試

android 仿微信demo——微信主界面實現(xiàn)

android 仿微信demo——微信主界面實現(xiàn)

總結

這篇關于微信demo的文章就到這里了,希望大家可以多多關注好吧啦網(wǎng)的更多精彩內容!

標簽: 微信
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲欧美日韩精品一区二区| 午夜欧美在线| 中文字幕一区二区精品区| 日韩欧美在线精品| 91亚洲精品在看在线观看高清| 国产精品网在线观看| 加勒比视频一区| av一区二区高清| 日韩国产欧美在线播放| 久久久免费人体| 午夜国产精品视频| 国产欧美亚洲一区| av中文字幕在线观看第一页| 亚洲第一区色| 欧美一区=区三区| 日本精品在线中文字幕| 中文字幕免费精品| 久久精品一区二区国产| 欧美综合另类| 国产精品一区二区三区美女 | 久久久久国产精品一区三寸| 中文字幕av一区二区三区人 | 欧美日韩国产观看视频| 亚洲美女久久| 天堂中文在线播放| 日韩成人在线看| 久久国产亚洲精品| 欧美亚洲网站| 免费精品国产的网站免费观看| 国产乱子精品一区二区在线观看| 久久影视一区| 国产精品中文字幕制服诱惑| 亚洲精华国产欧美| 丁香婷婷久久| 午夜电影一区| 欧美精选一区二区三区| 免费在线播放第一区高清av| 99国产成+人+综合+亚洲欧美| 国产精品一区二区三区av| 狠狠爱成人网| 日韩在线看片| 久久精品资源| 国产情侣久久| 亚洲影视一区| 九一成人免费视频| 超碰在线99| 国产美女亚洲精品7777| 亚洲精品第一| 久久福利毛片| 午夜国产一区二区| 亚洲人成在线网站| 国产日韩高清一区二区三区在线 | 羞羞答答国产精品www一本| xxxxx性欧美特大| 国产日韩欧美| 91免费精品国偷自产在线在线| 午夜亚洲福利在线老司机| 亚洲四虎影院| 中文字幕在线视频网站| 久久av国产紧身裤| 国产精品一区二区99| 日本一区二区三区视频在线看| 国精品一区二区三区| 激情国产在线| 精品国产精品国产偷麻豆| 国产精品免费精品自在线观看| 97久久亚洲| 日韩欧美中文字幕电影| 亚洲一级淫片| 性欧美长视频| 蜜臀va亚洲va欧美va天堂| 亚洲永久字幕| 丝袜国产日韩另类美女| 亚洲一区网站| 在线一区免费观看| 亚洲欧美视频| 亚洲精品看片| 青青草国产成人99久久| 久久精品99国产精品日本| 欧美日韩伊人| 麻豆视频观看网址久久| 国产午夜精品一区在线观看| 日韩激情网站| 国产日产精品_国产精品毛片 | 99成人在线| 四虎成人精品一区二区免费网站| 亚洲精品高潮| 国产亚洲欧美日韩精品一区二区三区 | 日产欧产美韩系列久久99| 欧美在线看片| 麻豆精品99| 日韩国产一区二区| 天堂日韩电影| 男人的天堂久久精品| 日韩精品免费视频人成| 欧美经典一区| 四虎4545www国产精品 | 日本在线啊啊| 五月精品视频| 日韩av网站在线免费观看| 国产精品magnet| 成人三级高清视频在线看| 久久精品官网| 亚洲字幕久久| 欧美精品97| 99久久精品国产亚洲精品| 老牛国产精品一区的观看方式| 日韩中文字幕无砖| 国模精品一区| 九一成人免费视频| 一二三区精品| 国际精品欧美精品| 国产偷自视频区视频一区二区| 91欧美极品| av亚洲一区二区三区| 午夜一区在线| 国产精品扒开腿做爽爽爽软件| 日韩精品不卡一区二区| 中文不卡在线| 久久影院资源站| 日韩午夜高潮| 久久99免费视频| 五月婷婷亚洲| 麻豆国产欧美日韩综合精品二区| 久久亚洲精品中文字幕蜜潮电影| 亚洲日产国产精品| 91视频精品| 亚洲视频二区| 岛国av免费在线观看| 日韩在线黄色| 久久五月天小说| 国产精品sss在线观看av| 欧美福利一区| 国产精品一区三区在线观看| 激情综合网站| 国产精品久久久久久久久免费高清 | 日韩精品免费视频人成| 99精品小视频| 欧美日韩一区二区高清| 久久一区二区三区电影| 国产欧美视频在线| 欧美日韩国产在线一区| 国产欧美91| 久久成人精品| 国产91欧美| 国产日本亚洲| 视频精品一区二区| 欧美视频二区| 日韩专区欧美专区| 久久久久国产精品一区二区| 国产精品777777在线播放| 夜夜嗨av一区二区三区网站四季av| 美女久久精品| 日韩av中文字幕一区| 中文在线一区| 日韩中文影院| 日韩av片子| 国产精品亲子伦av一区二区三区 | 好看的亚洲午夜视频在线| 亚洲天堂资源| 精品日本视频| 国产乱人伦丫前精品视频| 亚洲视频二区| 在线午夜精品| 久久婷婷丁香| 日韩高清中文字幕一区二区| 国产精品s色| 国产美女视频一区二区| 蜜臀av在线播放一区二区三区| 激情综合网站| 一区二区三区视频免费观看| 久久久久免费| 成人国产综合| 国产999精品在线观看| 精品一区91| 欧美国产日本| 久久精品免视看国产成人| 国产欧美综合一区二区三区| 欧美一区免费| 91亚洲无吗| 国产日产一区| 日韩在线视频一区二区三区| 综合亚洲色图| 久久亚洲欧美| 最新国产精品视频| 91大神在线观看线路一区| 亚洲精品九九| 日韩精品免费观看视频| 日韩福利在线观看| 日本精品在线播放| 日韩av三区| 免费在线日韩av| 欧美国产极品| 极品av在线| 久久久久99| 美女精品网站| 亚洲精品伊人| 国产激情久久| 日韩大片免费观看| 99精品在线观看|