日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > Android >内容正文

Android

Android UI(五)云通讯录项目之联系人列表,带侧滑选择,带搜索框

發(fā)布時(shí)間:2025/4/16 Android 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Android UI(五)云通讯录项目之联系人列表,带侧滑选择,带搜索框 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

作者:泥沙磚瓦漿木匠
網(wǎng)站
http://blog.csdn.net/jeffli1993
個(gè)人簽名:打算起手不凡寫出鴻篇巨作的人,往往堅(jiān)持不了完成第一章節(jié)。
交流QQ群:【
編程之美 365234583】http://jq.qq.com/?_wv=1027&k=XVfBTo

要捐錢的就打支付寶吧:13958686678(泥瓦匠開個(gè)玩笑~)

一、前言

??? 繼續(xù)AndroidUI系列,泥瓦匠又要開始扯淡了。哈哈今天在文章頭加了個(gè)支付寶賬號(hào)。我也真逗,至今沒收到一筆是寫博客的錢?;蚴欠窒淼?。泥瓦匠也就掛著逗逗樂而已。笑著就笑吧,我也在笑了。

??? 和我的師傅扯著蛋。也教授了泥瓦匠很多東西。泥瓦匠一直在學(xué)習(xí),一直在進(jìn)步而已。這是師傅送我的話:

睡少點(diǎn),玩少點(diǎn),分清主次拍優(yōu)先級(jí)。還要發(fā)揮同伴的能力,不是什么事情都要自己做的。

二、正文

??? 今天要講的內(nèi)容很多。還是主要大家去看代碼吧。我把主要的東西,介紹下。然后給源碼自己參透吧。下面給大家?guī)淼氖沁@一講,云通訊錄之聯(lián)系人列表,帶側(cè)滑選擇,帶搜索框。

??? 泥瓦匠的思路

  • 一個(gè)barTop層:兩個(gè)ImgView或是Button,一個(gè)TextView,用styles.xml控制其的樣式。
  • 核心中間listView 和 側(cè)滑View 搜索框View 自定義實(shí)現(xiàn)。這將是本講的重點(diǎn)?
  • 底部TextView的實(shí)現(xiàn)??????

三、實(shí)現(xiàn)核心代碼

??? 泥瓦匠剛剛吃完午飯,來扯會(huì)淡。路上遇到一對(duì)黑人唱著歌,朝著食堂吃飯去了。生活就需要這樣子,其樂融融。

??? 下面泥瓦匠先實(shí)現(xiàn)旁邊的側(cè)滑(SideBar),其實(shí)也就是和上一篇的Android UI(四)云通訊錄項(xiàng)目之云端更新進(jìn)度條實(shí)現(xiàn)中的自定義View一樣的。只要知道一些Canvas、Paint的一些基礎(chǔ)就好了。我們很簡(jiǎn)單的定義了一個(gè)26個(gè)字母的String數(shù)組,然后循環(huán)將他們Paint出來就好了。其實(shí)就是這么簡(jiǎn)單。

package org.nsg.views;import com.example.android05.R;import android.content.Context; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.graphics.Typeface; import android.graphics.drawable.ColorDrawable; import android.util.AttributeSet; import android.view.MotionEvent; import android.view.View; import android.widget.TextView;public class SideBar extends View {// touching eventprivate OnTouchingLetterChangedListener onTouchingLetterChangedListener;// 26 letterspublic static String[] b = {"A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V","W", "X", "Y", "Z", "#" };// if choosedprivate int choose = -1;private Paint paint = new Paint();private TextView mTextDialog;public void setmTextDialog(TextView mTextDialog){this.mTextDialog = mTextDialog;}public SideBar(Context context, AttributeSet attrs, int defStyleAttr){super(context, attrs, defStyleAttr);}public SideBar(Context context, AttributeSet attrs){super(context, attrs);}public SideBar(Context context){super(context);}// override onDraw functionprotected void onDraw(Canvas canvas){super.onDraw(canvas);// get the heightint height = getHeight();// get the widthint width = getWidth();// get one letter heightint singleHeight = height / b.length;for (int i = 0; i < b.length; i++){paint.setColor(Color.rgb(33, 65, 98));paint.setTypeface(Typeface.DEFAULT_BOLD);paint.setAntiAlias(true);paint.setTextSize(20);// if choosed if(i == choose){paint.setColor(Color.parseColor("#3399ff"));paint.setFakeBoldText(true);}// draw textfloat x = width / 2 - paint.measureText(b[i]) / 2;float y = singleHeight * i + singleHeight;canvas.drawText(b[i], x, y, paint);paint.reset();}}@SuppressWarnings("deprecation")@Overridepublic boolean dispatchTouchEvent(MotionEvent event){final int action = event.getAction();final float y = event.getY(); // get the Y final int oldChoose = choose;final OnTouchingLetterChangedListener changedListener = onTouchingLetterChangedListener;final int letterPos = (int)( y / getHeight() * b.length);switch (action){case MotionEvent.ACTION_UP:setBackgroundDrawable(new ColorDrawable(0x00000000));choose = -1;invalidate();if (mTextDialog != null)mTextDialog.setVisibility(View.INVISIBLE);break;default:setBackgroundResource(R.drawable.bg_sidebar);if (oldChoose != letterPos){if (letterPos >= 0 && letterPos < b.length){if (changedListener != null)changedListener.onTouchingLetterChanged(b[letterPos]);if (mTextDialog != null){mTextDialog.setText(b[letterPos]);mTextDialog.setVisibility(View.VISIBLE);}choose = letterPos;invalidate();}}break;}return true;}public void setOnTouchingLetterChangedListener(OnTouchingLetterChangedListener changedListener){this.onTouchingLetterChangedListener = changedListener;}public interface OnTouchingLetterChangedListener{public void onTouchingLetterChanged(String str);} }

? 既然做好了這個(gè),我們就實(shí)現(xiàn)這個(gè)listView,其實(shí)ListView是最好實(shí)現(xiàn)的。先定義一個(gè)ListView,然后再創(chuàng)一個(gè)相應(yīng)的item的xml。用代碼將它們循環(huán)一下就好。

? 下面是item的xml代碼:

<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="fill_parent"android:layout_height="match_parent"android:gravity="center_vertical"android:orientation="vertical" ><TextViewandroid:id="@+id/txt_catalog"android:layout_width="fill_parent"android:layout_height="wrap_content"android:layout_weight="1"android:paddingBottom="5dp"android:paddingTop="5dp"android:paddingLeft="12dp"android:text="A"android:textColor="@color/bluejeff"android:drawableBottom="@drawable/line_blue" /><RelativeLayout android:layout_width="wrap_content"android:layout_height="wrap_content"><ImageViewandroid:id="@+id/user_head"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_marginLeft="12dp"android:layout_marginTop="6dp"android:layout_marginBottom="6dp"android:background="@drawable/bg_border"android:src="@drawable/user_head" /><LinearLayout android:layout_width="match_parent"android:layout_height="wrap_content"android:layout_toRightOf="@id/user_head"android:background="@color/white"android:orientation="vertical"><TextViewandroid:id="@+id/txt_user_name"android:layout_width="wrap_content"android:layout_height="wrap_content"android:textColor="@color/black"android:layout_marginTop="12dp"android:layout_marginLeft="10dp"android:layout_marginBottom="6dp"android:textSize="20sp"android:text="Jeff Lee"/><TextViewandroid:id="@+id/txt_user_list_info"android:layout_width="wrap_content"android:layout_height="30dp"android:textSize="12sp"android:layout_marginLeft="10dp"android:text="IT部門 信息科"android:textColor="@color/gray" /></LinearLayout><TextViewandroid:id="@+id/txt_user_id"android:layout_width="wrap_content"android:layout_height="wrap_content"android:textColor="#336598"android:visibility="gone"android:text="1"/></RelativeLayout></LinearLayout>

? 然后我們實(shí)現(xiàn)那個(gè)搜索框,搜索框其實(shí)看上去就是個(gè)TextView。所以我們繼承TextView的類,并實(shí)現(xiàn)焦點(diǎn)控制的監(jiān)聽器等,讓這些更好的給我們用。難點(diǎn)也沒有,就是那個(gè)畫出搜索圖標(biāo)而已。代碼我下面也給出來了:

? 最后,大功告成。小結(jié)下,其實(shí)這個(gè)界面還有增加了一個(gè)SidleBar。在我們Android UI(三)SlidingMenu實(shí)現(xiàn)滑動(dòng)菜單(詳細(xì) 官方)這里講過的。因?yàn)閡ser有個(gè)組,或是在其中一本電話本里面的。然后一個(gè)界面大家別覺得它太麻煩。一個(gè)一個(gè)來,有成就感。老話說一句唄:打算起手不凡寫出鴻篇巨作的人,往往堅(jiān)持不了完成第一章節(jié)。

? 任何做事都一樣,注意細(xì)節(jié)。一步一步來,Think big, Start small, Scale fast.道理都知道,就去做唄。

四、總結(jié)

?? 本章關(guān)于云通訊錄的界面我會(huì)慢慢分享給大家。項(xiàng)目也放在下面的鏈接供大家下載學(xué)習(xí)。這個(gè)比較難,大家好好看代碼吧。關(guān)于代碼在下面的鏈接:http://files.cnblogs.com/Alandre/Android05.rar

?? 如以上文章或鏈接對(duì)你有幫助的話,別忘了在文章按鈕或到頁面右下角點(diǎn)擊 “贊一個(gè)” 按鈕哦。你也可以點(diǎn)擊頁面右邊“分享”懸浮按鈕哦,讓更多的人閱讀這篇文章

轉(zhuǎn)載于:https://www.cnblogs.com/Alandre/p/4143327.html

總結(jié)

以上是生活随笔為你收集整理的Android UI(五)云通讯录项目之联系人列表,带侧滑选择,带搜索框的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 久久精品国产亚洲AV成人婷婷 | 久久伊人成人 | 免费网站在线高清观看 | 综合性色 | 麻豆一区二区三区 | 女同视频网站 | 天堂网2020| 国产黑人| 综合色在线观看 | 国产一级特黄aaa大片 | 亚洲第八页 | 涩涩视屏| 国产精品电影网站 | 国产又黄又大又爽 | 久久www视频| 国产一级黄色大片 | 全国男人的天堂网 | 国产视频一区二区三 | 91精品色 | 国产午夜精品一区二区三区嫩草 | 黄色男同视频 | 狠狠躁日日躁夜夜躁 | 高清一区二区三区四区五区 | 美女热逼| 欧美亚洲黄色 | 久久综合爱| 2018国产精品 | 香蕉视频国产 | 亚洲福利视频在线 | 狠狠人妻久久久久久 | 久久久国产视频 | 黄骗免费网站 | 97精品国产97久久久久久春色 | 999精品免费视频 | 蜜桃久久av | 亚洲高清av| 日本公与丰满熄 | jvid乐乐| 中文字幕乱码人妻二区三区 | av老司机在线观看 | 欧美天堂视频 | 国产日本一区二区 | 日韩三级视频在线播放 | 成人人伦一区二区三区 | 亚洲一区二区三区免费观看 | 少妇一级淫片免费放 | 婷婷久久亚洲 | 国产福利视频一区二区 | 在线视频欧美一区 | 黑人多p混交群体交乱 | 日韩少妇内射免费播放18禁裸乳 | 狠狠鲁影院| 免看黄大片aa | 国产视频一区二区三区在线 | 国产精品jizz视频 | 久久亚洲成人av | 色五五月| 永久免费看mv网站入口78 | 伊人春色在线观看 | 黄色片在线观看视频 | 99re最新 | 欧美视频在线不卡 | 这里只有精品视频在线观看 | 亚洲精品无码久久久久久久 | 亚洲视频一区二区三区 | 亚洲性色av | 天堂久久爱| 久久精品亚洲一区 | 免费一二区 | 另类激情综合 | 亚洲无人区码一码二码三码的含义 | 91爱爱.com | 国产专区在线视频 | 校园春色 亚洲色图 | 日韩手机在线视频 | 欧美激情一级精品国产 | 亚洲精品在线免费观看视频 | 五月天综合在线 | 99这里都是精品 | 永久免费毛片 | 日本色妞| 久久久久久久久久久福利 | 亚洲成人一| 懂色av中文一区二区三区天美 | 久久99热人妻偷产国产 | 嫦娥性艳史bd| 精品国产一区在线观看 | 在线观看免费高清在线观看 | 日韩成人精品在线观看 | 一区二区三区高清不卡 | 国产人妖在线播放 | 欧美福利网 | 东京干手机福利视频 | 国语久久| 日韩欧美在线视频免费观看 | 欧美成人免费播放 | 欧美偷拍一区二区 | 致命弯道8在线观看免费高清完整 | 操日本女人 |