近日把weex 接入到我们的项目里面了,很感激阿里人创造的这个玩意,确实解决了移动端开发的两大痛点。好了 ,废话不多说,直接 接入———
快速接入:
- 在studio里面 新建一个安卓 工程比如叫做:Weex;
- 修改build.gradle 加入如下基础依赖:
compile 'com.alibaba:fastjson:1.1.46.android'
compile 'com.taobao.android:weex_sdk:0.5.1@aar'
### 代码实现:
- 实现图片下载接口,初始化时设置。
public class ImageAdapter implements IWXImgLoaderAdapter {
@Override
public void setImage(String url, ImageView view, WXImageQuality quality, WXImageStrategy strategy) {
//实现你自己的图片下载。
//本地图片统一规则:drawable://act_clothes_icon
if (!TextUtils.isEmpty(url)) {
if (url.startsWith("drawable://")) {
getImageBydrawableName(view, url);//获取drawable图片
return;
}
}
Picasso.with(view.getContext()).load(url).into(view);//获取网络图片
}
/**
* 通过反射获取drawable图片
* @param view
* @param url
*/
private void getImageBydrawableName(View view, String url) {
String urls[] = url.split("//");
String drawableName = "";
if(urls != null && urls.length >1) {
drawableName = urls[1];
}
try {
Field f = R.drawable.class.getField(drawableName);
view.setBackgroundResource(f.getInt(f));
} catch (NoSuchFieldException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
}
}
- 在Application种初始化Weex以及Adapter
package com.weex.sample;
import android.app.Application;
import com.taobao.weex.InitConfig;
import com.taobao.weex.WXSDKEngine;
/**
* 注意要在Manifest中设置android:name=".WXApplication"
* 要实现ImageAdapter 否则图片不能下载
* gradle 中一定要添加一些依赖,否则初始化会失败。
* compile 'com.android.support:recyclerview-v7:23.1.1'
* compile 'com.android.support:support-v4:23.1.1'
* compile 'com.android.support:appcompat-v7:23.1.1'
* compile 'com.alibaba:fastjson:1.1.45'
*/
public class WXApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
InitConfig config=new InitConfig.Builder().setImgAdapter(new ImageAdapter()).build();
WXSDKEngine.initialize(this,config);
}
}
- 开始渲染
@@@@ 需要在assets文件夹下面 传入一个本地的.js文件,例如”hello.js”;
package com.weex.sample;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import com.taobao.weex.IWXRenderListener;
import com.taobao.weex.WXSDKInstance;
import com.taobao.weex.common.WXRenderStrategy;
import com.taobao.weex.utils.WXFileUtils;
public class MainActivity extends AppCompatActivity implements IWXRenderListener {
WXSDKInstance mWXSDKInstance;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mWXSDKInstance = new WXSDKInstance(this);
mWXSDKInstance.registerRenderListener(this);
/**
* WXSample 可以替换成自定义的字符串,针对埋点有效。
* template 是.we transform 后的 js文件。
* option 可以为空,或者通过option传入 js需要的参数。例如bundle js的地址等。
* jsonInitData 可以为空。
* width 为-1 默认全屏,可以自己定制。
* height =-1 默认全屏,可以自己定制。
*/
mWXSDKInstance.render("WXSample", WXFileUtils.loadFileContent("hello.js", this), null, null, -1, -1, WXRenderStrategy.APPEND_ASYNC);
}
@Override
public void onViewCreated(WXSDKInstance instance, View view) {
setContentView(view);
}
@Override
public void onRenderSuccess(WXSDKInstance instance, int width, int height) {
}
@Override
public void onRefreshSuccess(WXSDKInstance instance, int width, int height) {
}
@Override
public void onException(WXSDKInstance instance, String errCode, String msg) {
}
@Override
protected void onResume() {
super.onResume();
if(mWXSDKInstance!=null){
mWXSDKInstance.onActivityResume();
}
}
@Override
protected void onPause() {
super.onPause();
if(mWXSDKInstance!=null){
mWXSDKInstance.onActivityPause();
}
}
@Override
protected void onStop() {
super.onStop();
if(mWXSDKInstance!=null){
mWXSDKInstance.onActivityStop();
}
}
@Override
protected void onDestroy() {
super.onDestroy();
if(mWXSDKInstance!=null){
mWXSDKInstance.onActivityDestroy();
}
}
}
**说明:**WXSDKInstance 提供了加载远程URL的方法:
/**
url 为远程bundle的网络地址
其他参数和render方法一致
**/
public void renderByUrl(String pageName, String url, Map<String, Object> options, final String jsonInitData, final int width, final int height, final WXRenderStrategy flag) {}
混淆规则:
-keep class com.taobao.weex.WXDebugTool{*;}
-keep class com.taobao.weex.devtools.common.LogUtil{*;}
-keep public class * extends com.taobao.weex.ui.component.WXComponent{*;}
-keepclassmembers class ** {
@com.taobao.weex.ui.component.WXComponentProp public *;
}
-keep class com.taobao.weex.bridge.**{*;}
-keep class com.taobao.weex.dom.**{*;}
-keep class com.taobao.weex.adapter.**{*;}
-keep class com.taobao.weex.common.**{*;}
-keep class * implements com.taobao.weex.IWXObject{*;}
-keep class com.taobao.weex.ui.**{*;}
-keep class com.taobao.weex.ui.component.**{*;}
-keep class com.taobao.weex.utils.**{
public <fields>;
public <methods>;
}
-keep class com.taobao.weex.view.**{*;}
-keep class com.taobao.weex.module.**{*;}
常见异常:
framework.js uninitialized.
wx_create_instance_erro
需要在builg.gradle中过滤掉一些so加载库,如下:
ndk {
abiFilters "armeabi-v7a", "x86","armeabi"
}
后期试水会陆续跟上,欢迎观看———-
- weex 在fragment 中使用:
package com.houbank.cucurbit.ui.weexui;
import android.content.Context;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.FrameLayout;
import com.houbank.cucurbit.R;
import com.taobao.weex.IWXRenderListener;
import com.taobao.weex.WXSDKInstance;
import com.taobao.weex.common.WXRenderStrategy;
import java.util.HashMap;
public class WeexFragment extends Fragment implements IWXRenderListener {
private static final String TAG = "weexFragment";
private String mBundleUrl;
private FrameLayout mContainer;
private WXSDKInstance mWXSDKInstance;
public WeexFragment() {
}
public static WeexFragment newInstance(String bundleUrl) {
WeexFragment fragment = new WeexFragment();
Bundle args = new Bundle();
Log.e(TAG, "newInstance: "+bundleUrl );
args.putString(WXSDKInstance.BUNDLE_URL, bundleUrl);
fragment.setArguments(args);
return fragment;
}
@Override
public void onAttach(Context context) {
super.onAttach(context);
}
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
View view = View.inflate(getActivity(), R.layout.fragment_weex, null);
mContainer = (FrameLayout) view.findViewById(R.id.fragment_container);
mBundleUrl = getArguments() != null ? getArguments().getString(WXSDKInstance.BUNDLE_URL) : null;
mWXSDKInstance = new WXSDKInstance(getActivity());
mWXSDKInstance.registerRenderListener(this);
HashMap<String, Object> options = new HashMap<>();
options.put(WXSDKInstance.BUNDLE_URL, mBundleUrl);
mWXSDKInstance.renderByUrl("Weex Fragment Sample", mBundleUrl, options, null, WXRenderStrategy.APPEND_ASYNC);
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
if (mContainer.getParent() != null) {
((ViewGroup) mContainer.getParent()).removeView(mContainer);
}
return mContainer;
}
@Override
public void onStart() {
super.onStart();
if (mWXSDKInstance != null) {
mWXSDKInstance.onActivityStart();
}
}
@Override
public void onResume() {
super.onResume();
if (mWXSDKInstance != null) {
mWXSDKInstance.onActivityResume();
}
}
@Override
public void onPause() {
super.onPause();
if (mWXSDKInstance != null) {
mWXSDKInstance.onActivityPause();
}
}
@Override
public void onStop() {
super.onStop();
if (mWXSDKInstance != null) {
mWXSDKInstance.onActivityStop();
}
}
@Override
public void onDestroy() {
super.onDestroy();
if (mWXSDKInstance != null) {
mWXSDKInstance.onActivityDestroy();
}
}
@Override
public void onDetach() {
super.onDetach();
}
@Override
public void onViewCreated(WXSDKInstance instance, View view) {
mContainer.addView(view);
}
@Override
public void onRenderSuccess(WXSDKInstance instance, int width, int height) {
Log.e(TAG, "onRenderSuccess: ");
}
@Override
public void onRefreshSuccess(WXSDKInstance instance, int width, int height) {
Log.e(TAG, "onRefreshSuccess: ");
}
@Override
public void onException(WXSDKInstance instance, String errCode, String msg) {
Log.e(TAG, "errCode---------: " + errCode + "----------------msg-" + msg);
}
}