PraiseTextView
說明
我是将朋友圈分成了幾個獨立子產品單獨自定義的View,通過回調完成互動,耦合性算是非常低了,主要有以下及部分:
1.評論布局(自定義TextView)
2.點贊布局(原理和評論的自定義TextView一樣,都是用的SpannableString)
3.圖檔清單(出門右轉,理論上沒有數量限制,和listView配合使用也很好,緩存也自己處理了)
我也是找第三方例子不好找,于是自己寫了一個,我和同僚還打算做一套IM系統,app和背景都要做,我們自己定義sdk,我們還要封裝H5,類似hbuilder如果有什麼問題,可以聯系我。
全是跳轉到GitHub上的連結,源碼也在GitHub上
示例

主要方法
mPraiseTextView.setData (mPraiseInfos);//設定資料
mPraiseTextView.setNameTextColor (Color.BLUE);//設定名字字型顔色
mPraiseTextView.setIcon (R.drawable.emoji_1f0cf);//設定圖示
mPraiseTextView.setMiddleStr (",");//設定分割文本
mPraiseTextView.setIconSize (new Rect (0,100,100));//設定圖示大小,預設與字号比對
mPraiseTextView.setonPraiseListener()//設定監聽
onClick (int position,PraiseTextView.PraiseInfo mPraiseInfo)
position是第幾個點贊的人,mInfo是這條點贊的資訊
onOtherClick
内部處理了點選文字會觸發兩個回調的問題,這個是點選非文字或者沒有單獨定義點選事件的回調
布局
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.lujianchao.praisetextview.MainActivity">
android:layout_width="match_parent"
android:id="@+id/praisetextview"
android:layout_height="wrap_content"
/>
android:id="@+id/log"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scrollbars="vertical"/>
public class MainActivity extends AppCompatActivity {
private PraiseTextView mPraiseTextView;
private TextView mTextView;
@Override
protected void onCreate (Bundle savedInstanceState) {
super.onCreate (savedInstanceState);
setContentView (R.layout.activity_main);
mPraiseTextView = (PraiseTextView) findViewById (R.id.praisetextview);
mTextView = (TextView) findViewById (R.id.log);
mTextView.setMovementMethod (ScrollingMovementMethod.getInstance ());
List mPraiseInfos = new ArrayList<> ();
mPraiseInfos.add (new PraiseTextView.PraiseInfo ().setId (111).setNickname ("張三").setlogo ("http://lujianchao.com/images/headimg/1.jpg"));
mPraiseInfos.add (new PraiseTextView.PraiseInfo ().setId (222).setNickname ("張四").setlogo ("http://lujianchao.com/images/headimg/2.jpg"));
mPraiseInfos.add (new PraiseTextView.PraiseInfo ().setId (333).setNickname ("張五").setlogo ("http://lujianchao.com/images/headimg/3.jpg"));
mPraiseInfos.add (new PraiseTextView.PraiseInfo ().setId (444).setNickname ("張六").setlogo ("http://lujianchao.com/images/headimg/4.jpg"));
mPraiseInfos.add (new PraiseTextView.PraiseInfo ().setId (555).setNickname ("趙四").setlogo ("http://lujianchao.com/images/headimg/5.jpg"));
mPraiseInfos.add (new PraiseTextView.PraiseInfo ().setId (666).setNickname ("趙三").setlogo ("http://lujianchao.com/images/headimg/6.jpg"));
mPraiseInfos.add (new PraiseTextView.PraiseInfo ().setId (777).setNickname ("李大").setlogo ("http://lujianchao.com/images/headimg/7.jpg"));
mPraiseInfos.add (new PraiseTextView.PraiseInfo ().setId (888).setNickname ("李二").setlogo ("http://lujianchao.com/images/headimg/8.jpg"));
mPraiseInfos.add (new PraiseTextView.PraiseInfo ().setId (999).setNickname ("李三").setlogo ("http://lujianchao.com/images/headimg/9.jpg"));
mPraiseTextView.setData (mPraiseInfos);//設定資料
mPraiseTextView.setNameTextColor (Color.BLUE);//設定名字字型顔色
mPraiseTextView.setIcon (R.drawable.emoji_1f0cf);//設定圖示
mPraiseTextView.setMiddleStr (",");//設定分割文本
mPraiseTextView.setIconSize (new Rect (0,100));//設定圖示大小,預設與字号比對
mPraiseTextView.setonPraiseListener (new PraiseTextView.onPraiseClickListener () {
@Override
public void onClick (final int position,final PraiseTextView.PraiseInfo mPraiseInfo) {
mTextView.append ("position = [" + position + "],mPraiseInfo = [" + mPraiseInfo + "]"+"\r\n");
}
@Override
public void onOtherClick () {
mTextView.append ("onOtherClick"+"\r\n");
}
});
}
}
以上就是本文的全部内容,希望對大家的學習有所幫助,也希望大家多多支援程式設計小技巧。
總結
如果覺得程式設計之家網站内容還不錯,歡迎将程式設計之家網站推薦給程式員好友。
本圖文内容來源于網友網絡收集整理提供,作為學習參考使用,版權屬于原作者。
小編個人微信号 jb51ccc
喜歡與人分享程式設計技術與工作經驗,歡迎加入程式設計之家官方交流群!