下面分析基于MeiZhi Version 2.6.2
須知少時凌云志,曾許人間第一流
LiteOrm NumberPRogressBar HeadsUp smooth-app-bar-layout
干貨集中營 API 文檔 GankApi BaseUrl http://gank.io/api/ 1. http://gank.io/api/data/福利/” + DrakeetFactory.meizhiSize + “/{page} ex: http://gank.io/api/data/福利/10/1 2. http://gank.io/api/day/{year}/{month}/{day} ex: http://gank.io/api/day/2017/1/22 3. http://gank.io/api/data/休息視頻/” + DrakeetFactory.meizhiSize + “/{page} ex: http://gank.io/api/data/休息視頻/10/1
DrakeetApi 1.BaseUrl https://leancloud.cn:443/1.1/classes/ ex https://leancloud.cn:443/1.1/classes/Gank?limit=1&where={“tag”:”2017-1-22”} 其中頭信息: X-LC-Id: 0azfScvBLCC9tAGRAwIhcC40 X-LC-Key: gAuE93qAusvP8gk1VW8DtOUb Content-Type: application/json
可以用Fiddler調試
Gson使用中遇到的Date格式問題 serializeNulls Android中Gson解析json數據使用@SerializedName注解與java對象不匹配的字段
App繼承自Application,在App中完成了Toasts工具類的注冊,及數據庫的的創建(LiteOrm),App的主題繼承自Theme.AppCompat.Light.NoActionBar,沒有ActionBar,以便自定義。
BaseActivity主要封裝了網絡請求sGankIO,以及在activity onDestroy時取消當前網絡的請求。 CompositeSubscription的作用:
為了防止可能的內存泄露,在你的 Activity 或 Fragment 的 onDestroy 里,用 Subscription.isUnsubscribed() 檢查你的 Subscription 是否是 unsubscribed。如果調用了 Subscription.unsubscribe() ,Unsubscribing將會對 items 停止通知給你的 Subscriber,并允許垃圾回收機制釋放對象,防止任何 RxJava 造成內存泄露。
給Android開發者的RxJava詳解
我所理解的RxJava——上手其實很簡單 [譯] 網絡請求框架 Retrofit 2 使用入門 DrakeetFactory 第一步-定義請求的Api
public interface GankApi { @GET("data/福利/" + DrakeetFactory.meizhiSize + "/{page}") Observable<MeizhiData> getMeizhiData(@Path("page") int page); @GET("day/{year}/{month}/{day}") Observable<GankData> getGankData( @Path("year") int year, @Path("month") int month, @Path("day") int day); @GET("data/休息視頻/" + DrakeetFactory.meizhiSize + "/{page}") Observable<休息視頻Data> get休息視頻Data(@Path("page") int page);}第二步-Retrofit客戶端
public class DrakeetRetrofit { final GankApi gankService; final DrakeetApi drakeetService; // @formatter:off final static Gson gson = new GsonBuilder() .setDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSS'Z'") .serializeNulls() .create(); // @formatter:on DrakeetRetrofit() { OkHttpClient.Builder httpClient = new OkHttpClient.Builder(); if (DrakeetFactory.isDebug) { //開啟log顯示到控制臺 HttpLoggingInterceptor logging = new HttpLoggingInterceptor(); logging.setLevel(HttpLoggingInterceptor.Level.BODY); httpClient.addInterceptor(logging); } httpClient.connectTimeout(12, TimeUnit.SECONDS); OkHttpClient client = httpClient.build(); Retrofit.Builder builder = new Retrofit.Builder(); builder.baseUrl("http://gank.io/api/") .client(client) .addCallAdapterFactory(RxJavaCallAdapterFactory.createWithScheduler(Schedulers.io())) .addConverterFactory(GsonConverterFactory.create(gson)); Retrofit gankRest = builder.build(); builder.baseUrl("https://leancloud.cn:443/1.1/classes/"); Retrofit drakeetRest = builder.build(); gankService = gankRest.create(GankApi.class); drakeetService = drakeetRest.create(DrakeetApi.class); } public GankApi getGankService() { return gankService; } public DrakeetApi getDrakeetService() { return drakeetService; }}第三部-生成單例GankApi實例
public class DrakeetFactory { protected static final Object monitor = new Object(); static GankApi sGankIOSingleton = null; static DrakeetApi sDrakeetSingleton = null; public static final int meizhiSize = 10; public static final int gankSize = 5; public static boolean isDebug = true; public static GankApi getGankIOSingleton() { synchronized (monitor) { if (sGankIOSingleton == null) { sGankIOSingleton = new DrakeetRetrofit().getGankService(); } return sGankIOSingleton; } } public static DrakeetApi getDrakeetSingleton() { synchronized (monitor) { if (sDrakeetSingleton == null) { sDrakeetSingleton = new DrakeetRetrofit().getDrakeetService(); } return sDrakeetSingleton; } }}ToolbarActivity繼承自BaseActivity ToolbarActivity主要設置了當前Activity的actionbar,可以給子類覆蓋重寫是否可以顯示返回上一個Activity按鈕,有顯示隱藏AppBarLayout方法。
繼承自ToolbarActivity的子類須include的layout
android:theme和app:popupTheme的作用,以及在android 3.0以下不起作用問題的解決 調用
setSupportActionBar(mToolbar);判斷是否有返回箭頭,ToolbarActivity默認是不顯示返回按鈕(即返回上一個Activity),需要子類覆蓋重寫。
ActionBar actionBar = getSupportActionBar(); //顯示返回的箭頭,并可通過onOptionsItemSelected()進行監聽,其資源ID為android.R.id.home。 if (actionBar != null) actionBar.setDisplayHomeAsUpEnabled(true);返回按鈕的點擊事件
@Override public boolean onOptionsItemSelected(MenuItem item) { if (item.getItemId() == android.R.id.home) { onBackPressed(); return true; } else { return super.onOptionsItemSelected(item); } }顯示或隱藏ToolBar
protected void hideOrShowToolbar() { mAppBar.animate() .translationY(mIsHidden ? 0 : -mAppBar.getHeight()) .setInterpolator(new DecelerateInterpolator(2)) .start(); mIsHidden = !mIsHidden; }SwipeRefreshBaseActivity繼承自ToolbarActivity封裝了SwipeRefreshLayout的請求狀態和配置了請求的UI效果。
設置旋轉箭頭的顏色變化
mSwipeRefreshLayout.setColorSchemeResources(R.color.refresh_progress_3, R.color.refresh_progress_2, R.color.refresh_progress_1);MainActivity繼承自SwipeRefreshBaseActivity 浮動操作按鈕詳解
待續….
新聞熱點
疑難解答