Android繪制炫酷引導(dǎo)界面
一個(gè)超炫的引導(dǎo)界面,分享給大家

代碼:
MainActivity.java
package com.bzu.gxs.webview1;
import android.app.Activity;
import android.os.Build;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.KeyEvent;
import android.view.Menu;
import android.view.MenuItem;
public class MainActivity extends Activity {
private MyWebView myWebView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
myWebView = (MyWebView) findViewById(R.id.webView);
myWebView.getSettings().setJavaScriptEnabled(true);
init();
myWebView.loadUrl("http://h5.eqxiu.com/s/F93iW6fu");
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.my, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if (keyCode == KeyEvent.KEYCODE_BACK && myWebView.canGoBack()) {
myWebView.goBack();
return true;
}
return super.onKeyDown(keyCode, event);
}
public void init(){
if(Build.VERSION.SDK_INT >= 19) {
myWebView.getSettings().setLoadsImagesAutomatically(true);
} else {
myWebView.getSettings().setLoadsImagesAutomatically(false);
}
}
}
MyWebView.java
package com.bzu.gxs.webview1;
import android.content.Context;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.webkit.WebChromeClient;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.ProgressBar;
import android.widget.Toast;
/**
* Created by GXS on 2016/5/12.
*/
public class MyWebView extends WebView{
private ProgressBar progressBar;
private Context mContext;
public MyWebView(Context context, AttributeSet attributeSet) {
super(context,attributeSet);
mContext = context;
progressBar = (ProgressBar) LayoutInflater.from(context).inflate(R.layout.progressbar,null);
progressBar.setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT,6,0,0));
addView(progressBar);
setWebChromeClient(new WebChromeClient());
setWebViewClient(new WebViewClient(){
@Override
public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {
Toast.makeText(mContext,"Gxs"+description,Toast.LENGTH_SHORT).show();
}
});
this.getSettings().setBuiltInZoomControls(true);
this.getSettings().setUseWideViewPort(true);
}
public class WebChromeClient extends android.webkit.WebChromeClient {
@Override
public void onProgressChanged(WebView view, int newProgress) {
if (newProgress == 100) {
progressBar.setVisibility(GONE);
} else {
if (progressBar.getVisibility() == GONE)
progressBar.setVisibility(VISIBLE);
progressBar.setProgress(newProgress);
}
super.onProgressChanged(view,newProgress);
}
}
@Override
protected void onScrollChanged(int l, int t, int oldl, int oldt) {
LayoutParams layoutParams = (LayoutParams) progressBar.getLayoutParams();
layoutParams.x = l;
layoutParams.y = t;
progressBar.setLayoutParams(layoutParams);
super.onScrollChanged(l, t, oldl, oldt);
}
}
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<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.bzu.gxs.webview1.MainActivity">
<com.bzu.gxs.webview1.MyWebView
android:id="@+id/webView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:text="Hello World!" />
</RelativeLayout>
progressbar.xml
<?xml version="1.0" encoding="utf-8"?> <ProgressBar xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/ProgressBar" style="?android:attr/progressBarStyleHorizontal" android:layout_width="match_parent" android:layout_height="wrap_content" android:indeterminate="false" android:maxHeight="10dip" android:minHeight="10dip" android:progress="50" android:progressDrawable="@drawable/greenprogress" />
注意: 需要在清單文件 AndroidManifest.xml 中加入:
<uses-permission android:name="android.permission.INTERNET"/>
以上就是本文的全部?jī)?nèi)容,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- Android客戶(hù)端首次啟動(dòng)引導(dǎo)界面
- Android UI設(shè)計(jì)與開(kāi)發(fā)之實(shí)現(xiàn)應(yīng)用程序只啟動(dòng)一次引導(dǎo)界面
- Android UI設(shè)計(jì)與開(kāi)發(fā)之仿人人網(wǎng)V5.9.2最新版引導(dǎo)界面
- Android UI設(shè)計(jì)與開(kāi)發(fā)之ViewPager仿微信引導(dǎo)界面以及動(dòng)畫(huà)效果
- Android UI設(shè)計(jì)與開(kāi)發(fā)之ViewPager介紹和簡(jiǎn)單實(shí)現(xiàn)引導(dǎo)界面
- Android繪制炫酷的引導(dǎo)界面
- Android利用ViewPager實(shí)現(xiàn)用戶(hù)引導(dǎo)界面效果的方法
- 很贊的引導(dǎo)界面效果Android控件ImageSwitcher實(shí)現(xiàn)
- android 引導(dǎo)界面的實(shí)現(xiàn)方法
- Android自定義ViewGroup實(shí)現(xiàn)豎向引導(dǎo)界面
相關(guān)文章
Android開(kāi)發(fā)微信APP支付功能的要點(diǎn)小結(jié)
微信支付現(xiàn)在在日常生活中隨處可見(jiàn),而關(guān)于Android開(kāi)發(fā)微信支付的文章網(wǎng)上也很多,所以這篇文章主要介紹的是在Android開(kāi)發(fā)微信APP支付功能的要注意的要點(diǎn),有需要的可以參考借鑒。2016-08-08
Android App實(shí)現(xiàn)監(jiān)聽(tīng)軟鍵盤(pán)按鍵的三種方式
本篇文章主要介紹Android App實(shí)現(xiàn)監(jiān)聽(tīng)軟鍵盤(pán)按鍵的三種方式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-03-03
Android多線(xiàn)程處理機(jī)制中的Handler使用介紹
本文將為大家介紹下Android的Handler的使用方法,Handler可以發(fā)送Messsage和Runnable對(duì)象到與其相關(guān)聯(lián)的線(xiàn)程的消息隊(duì)列,感興趣的朋友可以了解下哈2013-06-06
android 多點(diǎn)觸摸圖片縮放的具體實(shí)現(xiàn)方法
2013-06-06
Android傳感器SensorEventListener之加速度傳感器
今天小編就為大家分享一篇關(guān)于Android傳感器SensorEventListener之加速度傳感器,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-02-02
Android實(shí)現(xiàn)微信右側(cè)頂部下拉對(duì)話(huà)框
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)微信右側(cè)頂部下拉對(duì)話(huà)框,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12
Android開(kāi)發(fā)實(shí)現(xiàn)webview中img標(biāo)簽加載本地圖片的方法
這篇文章主要介紹了Android開(kāi)發(fā)實(shí)現(xiàn)webview中img標(biāo)簽加載本地圖片的方法,結(jié)合實(shí)例形式分析了webview加載本地圖片的步驟與相關(guān)操作技巧,需要的朋友可以參考下2017-10-10

