麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 系統 > Android > 正文

Android自定義View仿探探卡片滑動效果

2019-10-21 21:27:02
字體:
來源:轉載
供稿:網友

Android自定義View仿探探卡片滑動這種效果網上有很多人已經講解了實現思路,大多都用的是RecyclerView來實現的,但是我們今天來換一種實現思路,只用一個自定義的ViewGroup來搞定這個實現。

下面我們先看一下實現的效果: 

 Android,自定義View,仿探探,卡片滑動<

這個自定義View用法也很簡單,首先從github上下載或者fork這個項目,在布局中添加:

<com.liyafeng.view.swipecard.SwipeCardLayout  android:id="@+id/scl_layout"  android:layout_width="match_parent"  android:layout_height="match_parent"/>

是的,沒有一點廢話,自定義屬性可以根據自己的需求來添加。下面是代碼中初始化:

public class SwipeCardActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  setContentView(R.layout.activity_swipe_card);  SwipeCardLayout scl_layout=(SwipeCardLayout)findViewById(R.id.scl_layout);  Queue<CardEntity> data = new LinkedList<>();  CardEntity cardEntity1 = new CardEntity(R.drawable.f1, "這里是美麗的湖畔");  CardEntity cardEntity2 = new CardEntity(R.drawable.f2, "這里游泳比較好");  CardEntity cardEntity3 = new CardEntity(R.drawable.f3, "向往的藍天白云");  CardEntity cardEntity4 = new CardEntity(R.drawable.f4, "繁華的都市");  CardEntity cardEntity5 = new CardEntity(R.drawable.f5, "草原象征著理想");  data.add(cardEntity1);  data.add(cardEntity2);  data.add(cardEntity3);  data.add(cardEntity4);  data.add(cardEntity5);  scl_layout.setAdapter(new SwipeCardLayout.CardAdapter<CardEntity>(data) {   @Override   public View bindLayout() {    return LayoutInflater.from(SwipeCardActivity.this).inflate(R.layout.card_layout,null);   }   @Override   public void bindData(CardEntity data, View convertView) {    ImageView iv_card = (ImageView)convertView.findViewById(R.id.iv_card);    TextView tv_card = (TextView) convertView.findViewById(R.id.tv_card);    iv_card.setImageResource(data.resId);    tv_card.setText(data.content);   }  });  scl_layout.setOnSwipeListener(new SwipeCardLayout.OnSwipeListener() {   @Override   public void onSwipe(int type) {    switch (type) {     case SwipeCardLayout.TYPE_RIGHT:      Toast.makeText(SwipeCardActivity.this, "right", Toast.LENGTH_SHORT).show();      break;     case SwipeCardLayout.TYPE_LEFT:      Toast.makeText(SwipeCardActivity.this, "left", Toast.LENGTH_SHORT).show();      break;    }   }  }); }  class CardEntity {  public CardEntity(int resId, String content) {   this.resId = resId;   this.content = content;  }  public int resId;  public String content; }}

這里必須要用一個隊列來添加數據,顯示的順序就是隊列的順序。完整的代碼已經上傳github

接下來簡單說一下實現原理,我們用兩個自定義的ViewGroup來定義兩個Card,一個在上,一個在下,且重寫它的onTouchEvent()方法,來實現跟隨手指來滑動。當我們松開手指的時候,如果Card移動的距離短,那么就執行動畫將Card重置到原來位置,如果移動的距離比較遠,我們就執行動畫將Card移出屏幕,當動畫結束后,我們將下面的Card通過View的bringToFront()方法移動到上層,而剛剛移出屏幕的那個Card就會到下層,然后再將它重置到起始位置即可。 
這樣我們通過兩個Card交替來實現了視圖的復用,這是這個控件的核心部分。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 成人短视频在线播放 | 日韩欧美高清一区 | 国产视频在线观看一区二区三区 | 91精品国产乱码久久久久久久久 | 99国产精品国产免费观看 | 成人一区二区三区在线 | 亚洲黑人在线观看 | 精品国产乱码久久久久久丨区2区 | 性欧美xxxx极品摘花 | 黄污在线看 | 一级全毛片 | 91成人一区 | 久久国产成人精品国产成人亚洲 | 美女污污视频在线观看 | 国产精品久久久久久久久久久久久久久久 | 欧美一区在线观看视频 | 国产欧美精品一区二区三区四区 | 久草在线播放视频 | 精品欧美一区二区精品久久 | 九九午夜 | 国产亚洲精品综合一区91555 | 中文在线观看www | 黄a大片| 国产伦精品一区二区三区在线 | 一区二区久久精品66国产精品 | 激情小说激情图片激情电影 | 中文字幕免费一区 | 在线天堂中文在线资源网 | 羞羞视频免费网站男男 | 中文字幕精品在线视频 | 九九热在线视频观看 | 毛片视频免费观看 | 成人毛片视频在线播放 | 欧美精品成人一区二区三区四区 | 国产一级在线免费观看 | 日本网站在线播放 | 蜜桃视频最新网址 | 92看片淫黄大片欧美看国产片 | 一区二区三区手机在线观看 | 亚洲成人黄色片 | 精品国内视频 |