国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Android > 正文

新浪微博第三方登錄界面上下拉伸圖片之第三方開源PullToZoomListViewEx(一)

2020-04-11 11:13:17
字體:
來源:轉載
供稿:網友

Android PullZoomView是github上面的一個第三方開源項目,該項目實現的功能被新浪微博的移動端廣泛使用,其效果就是,當用戶在下拉過程中,頭部的圖片會有一定的拉伸,當用戶松開時候,圖片又收縮復位,下載地址:https://github.com/Frank-Zhu/PullZoomView

PullZoomView要實現兩類,一類是典型的Android ListView,另外一類是Android 的scroll view。本文先介紹PullZoomView在ListView上的實現:PullToZoomListViewEx。

首先需要把PullToZoomListViewEx像ListView一樣寫進布局:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context="com.zzw.testpullzoomview.MainActivity" ><com.ecloud.pulltozoomview.PullToZoomListViewExxmlns:custom="http://schemas.android.com/apk/res-auto"android:id="@+id/listView"android:layout_width="match_parent"android:layout_height="match_parent"custom:headerView="@layout/head_view"custom:zoomView="@layout/head_zoom_view" /></RelativeLayout>

需要注意的是,需要定義一個headerView:

custom:headerView="@layout/head_view"<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:id="@+id/layout_view"android:layout_width="match_parent"android:layout_height="match_parent"android:layout_gravity="bottom"android:gravity="bottom"><ImageViewandroid:id="@+id/iv_user_head"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_centerInParent="true"android:background="@android:color/holo_red_light"android:src="@drawable/ic_launcher" /><TextViewandroid:id="@+id/tv_user_name"android:textSize="sp"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_below="@id/iv_user_head"android:layout_centerHorizontal="true"android:text="新浪微博"android:textColor="#ffffff" /><LinearLayoutandroid:id="@+id/ll_action_button"android:layout_width="match_parent"android:layout_height="wrap_content"android:background="#"android:layout_alignParentBottom="true"android:padding="dip"><TextViewandroid:id="@+id/tv_register"android:layout_width="match_parent"android:layout_height="wrap_content"android:text="注冊"android:layout_weight=""android:textSize="sp"android:gravity="center"android:layout_gravity="center"android:textColor="#ffffff" /><TextViewandroid:id="@+id/tv_login"android:layout_width="match_parent"android:layout_height="wrap_content"android:text="登錄"android:layout_weight=""android:textSize="sp"android:gravity="center"android:layout_gravity="center"android:textColor="#ffffff" /></LinearLayout></RelativeLayout> 

此處的headerView是位于PullToZoomListViewEx頭部的一個子布局,里面定義一些控件將出現在PullToZoomListViewEx的頭部,但此處的headerView并不會縮放,只是可以看到此處的headerView在隨著下拉過程中移位。

而定義的custom:zoomView:

custom:zoomView="@layout/head_zoom_view"<?xml version="." encoding="utf-"?><ImageView xmlns:android="http://schemas.android.com/apk/res/android"android:id="@+id/imageView"android:layout_width="match_parent"android:layout_height="match_parent"android:layout_gravity="center_horizontal"android:scaleType="centerCrop"android:src="@drawable/a" /> 

head_zoom_view其實就是簡單的放一張圖片。

則是真正的要縮放伸展的View,此處通常會放置一張圖片,在用戶下拉過程中滑動縮放,產生奇妙的視覺效果。
在一定程度上講,zoomView是襯托在headerView底下的。headerView是一個正常顯示的Android View布局,而zoomView則是可以產生動態縮放和收縮效果的特殊zoom View。
寫一個完整的例子加以說明。

Java代碼:

package com.zzw.testpullzoomview;import com.ecloud.pulltozoomview.PullToZoomListViewEx;import android.app.Activity;import android.os.Bundle;import android.util.DisplayMetrics;import android.util.Log;import android.view.View;import android.widget.AbsListView;import android.widget.AdapterView;import android.widget.AdapterView.OnItemClickListener;import android.widget.ArrayAdapter;public class MainActivity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);PullToZoomListViewEx listView = (PullToZoomListViewEx) findViewById(R.id.listView);String data[] = new String[];for (int i = ; i < data.length; i++) {data[i] = "測試數據" + i;}listView.setAdapter(new ArrayAdapter<String>(this, android.R.layout.simple_list_item_, data));listView.getPullRootView().setOnItemClickListener(new OnItemClickListener() {@Overridepublic void onItemClick(AdapterView<?> parent, View view, int position, long id) {Log.d("position", "getPullRootView--->position = " + position);}});listView.setOnItemClickListener(new OnItemClickListener() {@Overridepublic void onItemClick(AdapterView<?> parent, View view, int position, long id) {Log.d("position", "position = " + position);}});setPullToZoomListViewExHeaderLayoutParams(listView);}// 設置頭部的View的寬高。private void setPullToZoomListViewExHeaderLayoutParams(PullToZoomListViewEx listView) {DisplayMetrics localDisplayMetrics = new DisplayMetrics();getWindowManager().getDefaultDisplay().getMetrics(localDisplayMetrics);int mScreenHeight = localDisplayMetrics.heightPixels;int mScreenWidth = localDisplayMetrics.widthPixels;AbsListView.LayoutParams localObject = new AbsListView.LayoutParams(mScreenWidth,(int) (.f * (mScreenWidth / .F)));listView.setHeaderLayoutParams(localObject);}}

以上所述是本文關于新浪微博第三方登錄界面上下拉伸圖片之第三方開源PullToZoomListViewEx(一)的全部敘述,希望大家喜歡,下篇給大家介紹新浪微博第三方登錄界面上下拉伸圖片之第三方開源PullToZoomListViewEx(二),希望大家繼續關注。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 北海市| 子长县| 嘉祥县| 青龙| 博客| 西和县| 安多县| 禄劝| 平利县| 高台县| 舞阳县| 泗洪县| 体育| 陆良县| 菏泽市| 莒南县| 隆昌县| 治县。| 通州区| 监利县| 贵州省| 肃宁县| 建湖县| 许昌市| 台江县| 石阡县| 红桥区| 巴林左旗| 淮南市| 潼南县| 株洲县| 富锦市| 象山县| 泰来县| 泉州市| 甘德县| 金溪县| 固阳县| 印江| 左云县| 赤峰市|