android webview 上拉加载动画,Android 之WebView实现下拉刷新和其他相关刷新功能

最近项目中需要用到WebView下拉刷新的功能,经过查找资料终于完成了此功能,现在拿出来和大家分享一下。希望对大家有所帮助。

效果如下图:

074639ac7277

image

074639ac7277

image

代码:

activity.xml

xmlns:tools="http://schemas.android.com/tools"

android:id="@+id/activity_main"

android:layout_width="match_parent"

android:layout_height="match_parent"

tools:context="com.zq.pullrefreshwebview.MainActivity">

android:id="@+id/rotate_header_web_view_frame"

xmlns:cube_ptr="http://schemas.android.com/apk/res-auto"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:background="@android:color/white"

cube_ptr:ptr_duration_to_close="200"

cube_ptr:ptr_duration_to_close_header="1000"

cube_ptr:ptr_keep_header_when_refresh="true"

cube_ptr:ptr_pull_to_fresh="false"

cube_ptr:ptr_ratio_of_header_height_to_refresh="1.2"

cube_ptr:ptr_resistance="1.8">

android:id="@+id/webview"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

/>

Activity.Java

/****

* WebView 实现下拉加载

*/

public class MainActivity extends AppCompatActivity {

private PtrClassicFrameLayout mPtrFrame;

private WebView mWebView;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

mWebView= (WebView) findViewById(R.id.webview);

mPtrFrame= (PtrClassicFrameLayout) findViewById(R.id.rotate_header_web_view_frame);

initView();

}

private void initView(){

mWebView.setWebViewClient(new WebViewClient() {

@Override

public boolean shouldOverrideUrlLoading(WebView view, String url) {

if(url.toLowerCase().startsWith("http://") || url.toLowerCase().startsWith("https://"))

{

return false;

}

return true;

}

@Override

public void onPageFinished(WebView view, String url) {

mPtrFrame.refreshComplete();

}

});

mPtrFrame.setLastUpdateTimeRelateObject(this);

mPtrFrame.setPtrHandler(new PtrHandler() {

@Override

public boolean checkCanDoRefresh(PtrFrameLayout frame, View content, View header) {

return PtrDefaultHandler.checkContentCanBePulledDown(frame, mWebView, header);

}

@Override

public void onRefreshBegin(PtrFrameLayout frame) {

updateData();

}

});

mPtrFrame.setResistance(1.7f);

mPtrFrame.setRatioOfHeaderHeightToRefresh(1.2f);

mPtrFrame.setDurationToClose(200);

mPtrFrame.setDurationToCloseHeader(1000);

mPtrFrame.setPullToRefresh(false);

mPtrFrame.setKeepHeaderWhenRefresh(true);

mPtrFrame.postDelayed(new Runnable() {

@Override

public void run() {

mPtrFrame.autoRefresh();

}

}, 100);

}

private void updateData() {

mWebView.loadUrl("https://my.oschina.net/zhangqie/blog");

}

}

权限:

注:上图效果是参考他人写的

074639ac7277

image

更多实现方式

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值