收集了Android開發中常用而且好用的方法,API等,持續更新中
文内容來自各個網站收集整理,有些覺得在平常開發中用處比較大就記錄了下來,可能存在重複的整理。
- getParent().requestDisallowInterceptTouchEvent(true);剝奪父view 對touch 事件的處理權,誰用誰知道。
- Canvas中clipRect、clipPath和clipRegion 剪切區域的API。
- Bitmap.extractAlpha ();傳回一個新的Bitmap,capture原始圖檔的alpha 值。有的時候我們需要動态的修改一個元素的背景圖檔又不希望使用多張圖檔的時候,通過這個方法,結合Canvas 和Paint 可以動态的修改一個純色Bitmap的顔色。
- HandlerThread,代替不停new Thread 開子線程的重複體力寫法。
- IntentService,一個可以幹完活後自己去死且不需要我們去管理子線程的Service。
- Palette,5.0加入的可以提取一個Bitmap 中突出顔色的類,結合上面的Bitmap.extractAlpha,你懂的。
- Executors. newSingleThreadExecutor();這個是java 的,之前不知道它,自己花很大功夫去研究了單線程順序執行的任務隊列。。
- android:animateLayoutChanges=”true”,LinearLayout中添加View 的動畫的辦法,支援通過setLayoutTransition()自定義動畫。
- ViewDragHelper,自定義一個子View可拖拽的ViewGroup 時,處理各種事件很累吧,嗯? 什麼鬼?
- GradientDrawable,之前接手公司的項目,發現有個陰影效果還不錯,以為是切的圖檔,一看代碼,= =!
- AsyncQueryHandler,如果做系統工具類的開發,比如聯系人短信輔助工具等,肯定免不了和ContentProvider打交道,如果資料量不是很大的情況下,随便搞,如果資料量大的情況下,了解下這個類是很有必要的,需要注意的是,這玩意兒吃異常..
- android util包中的Pair類,可以友善的用來存儲一”組”資料。注意不是key value。
- PointF,graphics包中的一個類,我們經常見到在處理Touch事件的時候分别定義一個downX,一個downY用來存儲一個坐标,如果坐标少還好,如果要記錄的坐标過多那代碼就不好看了。用PointF(float x, float y);來描述一個坐标點會清楚很多。
- android:descendantFocusability,ListView的item中CheckBox等元素搶焦點導緻item點選事件無法響應時,除了給對應的元素設定 focusable,更簡單的是在item根布局加上android:descendantFocusability=”blocksDescendants”
- Messenger,面試的時候通常都會被問到程序間通信,一般情況下大家都是開始背書,AIDL巴拉巴拉。。有一天在鴻神的部落格看到這個,嗯,如他所說,又可以裝一下了。
- TextView.setError();用于驗證使用者輸入。
- ViewConfiguration.getScaledTouchSlop();觸發移動事件的最小距離,自定義View處理touch事件的時候,有的時候需要判斷使用者是否真的存在movie,系統提供了這樣的方法。
- ValueAnimator.reverse(); 順暢的取消動畫效果。
- ViewStub,有的時候一塊區域需要根據情況顯示不同的布局,通常我們都會通過setVisibility的方法來顯示和隐藏不同的布局,但是這樣預設是全部加載的,用ViewStub可以更好的提升性能。
- onTrimMemory,在Activity中重寫此方法,會在記憶體緊張的時候回調(支援多個級别),便于我們主動的進行資源釋放,避免OOM。
- EditTxt.setImeOptions, 使用EditText彈出軟鍵盤時,修改Enter鍵的顯示内容(一直很讨厭用Enter鍵來互動,是以之前一直不知道這玩意兒)
- TextView.setCompoundDrawablePadding,代碼設定TextView的drawable padding。
- ImageSwitcher,可以用來做圖檔切換的一個類,類似于幻燈片。
- WeakHashMap,直接使用HashMap有時候會帶來記憶體溢出的風險,使用WaekHashMap執行個體化Map。當使用者不再有對象引用的時候,WeakHashMap将自動被移除對應Key值的對象。
- setBackgroundResource(0) 可以移除 View 的背景色
- Resources.getSystem().getDisplayMetrics().density 可以不用 Context 也能擷取螢幕密度哦
- 通過重載 ViewGroup 的 dispatchDraw 可以實作一個簡單的蒙版效果。 例如下拉重新整理時,可以在 contentView 上加一層遮罩。 canvas.drawRect(0, mContentView.getTranslationY(), getWidth(), getHeight(), mMaskPaint);
- new 出來的 View 可以用 View.generateViewId() (API 17 以上可用) 生成 id,系統保證唯一
- 使用 GridView時 android:padding 和 android:clipToPadding=”false” 配合使用效果更好哦。
- 在布局檔案中,如果隻是為了占位,可以用 Space 來取代 View。 最棒的一點是Space可以跳過 Draw 這個過程。
- TypedValue.applyDimension(int unit, float value, DisplayMetrics metrics) 友善dp, px, sp 之間的轉換。
- Activity.startActivities() 這個方法最直接的了解就是使用intent開啟多個Activity
- TextUtils.isEmpty() 如果傳入的String 為NULL或者Length為0的話就傳回 true。
-
Html.fromHtml() 如果你對Html熟悉的話,可以很迅速通過這個方法處理一些富文本操作。比如超連結和圖文排版等處理。
例如:
linkView.setText(
Html.fromHtml(
"<b>fromHtml:</b> \t Click " +
"<a href=\"http://oakzmm.com\">here</a> " +
"to visit my website "
)
);
- Build.VERSION_CODES 有些時候我們的app需要根據不同的SDK版本進行執行不同的操作
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
ActionBar actionBar = getActionBar();
actionBar.setDisplayHomeAsUpEnabled(true);
}
- PhoneNumberUtils.convertKeypadLettersToDigits 這個方法簡單粗暴,會将輸入的字母根據鍵盤上的映射轉換為數字。
-
ArgbEvaluator ArgbEvaluator.evaluate(float fraction, Object startValue, Object endValue);根據一個起始顔色值和一個結束顔色值以及一個偏移量生成一個新的顔色,分分鐘實作類似于微信底部欄滑動顔色漸變。
這裡提供另一個顔色漸變的版本
From Google Sample SlidingTabsColors下的 SlidingTabStrip.java
/**
* Blend {@code color1} and {@code color2} using the given ratio.
*
* @param ratio of which to blend. 1.0 will return {@code color1}, 0.5 will give an even blend,
* 0.0 will return {@code color2}.
*/
private static int blendColors(int color1, int color2, float ratio) {
final float inverseRation = f - ratio;
float r = (Color.red(color1) * ratio) + (Color.red(color2) * inverseRation);
float g = (Color.green(color1) * ratio) + (Color.green(color2) * inverseRation);
float b = (Color.blue(color1) * ratio) + (Color.blue(color2) * inverseRation);
return Color.rgb((int) r, (int) g, (int) b);
}
- ValueAnimator.reverse() 順暢的取消動畫效果
- DateUtils.formatDateTime()) 這個方法可以輸出相應格式化的時間或者日期
- Pair 這個類 可以用來存儲存儲一”組”資料。但不是key和value的關系。
- SparseArray 目前有很多地方從性能優化方說使用SparseArray來替換- - hashMap,來節省記憶體,提高性能。
- Linkify.addLinks() 這個類可以更友善的為文本添加超連結。
- android.media.ThumbnailUtils這個類主要是用來處理縮略圖相關的工作,比如:用來擷取媒體(圖檔、視訊)的縮略圖;
- 子產品間有消息需要傳遞時,使用LocalBroadcastManager替代Listener進行子產品解耦。除了解耦,這樣發送消息和執行消息差一個線程循環,可以減小方法的調用鍊,我這就碰到一次方法調用鍊太長導緻StackOverflow的問題。
- 靜态變量不要直接或者間接引用Activity、Service等。這會使用Activity以及它所引用的所有對象無法釋放,然後,使用者操作時間一長,記憶體就會狂升。
- Handler機制有一個特點是不會随着Activity、Service的生命周期結束而結束。也就是說,如果你Post了一個Delay的Runnable,然後在Runnable執行之前退出了Activity,Runnable到時間之後還是要執行的。如果Runnable裡面包含更新View的操作,程式崩潰了。
- 不少人在子線程中更新View時喜歡使用Context.runOnUiThread,這個方法有個缺點,就是一但Context生命周期結束,比如Activity已經銷毀時,一調用就會崩潰。
- SharedPreferences.Editor.commit這個方法是同步的,一直到把資料同步到Flash上面之後才會傳回,由IO操作的不可控,盡量使用apply方法代替。apply隻在API Level>=9才會支援,需要做相容。不過,最新的 support v4 包已經為我們做好了處理,使用 SharedPreferencesCompat.EditorCompat.getInstance().apply(editor) 即可。
- PackageManager.getInstalledPackages這個方法經常使用,你可能不知道,當擷取的結果數量比較多的時候,在某些機型上面調用它花費的時間可能秒級的,是以盡量在子線程中使用。另外,如果結果太多,超過系統設定的Binder資料最大傳輸量的上限,則會發生TransactionException,如果你使用這個方法擷取機器上的己安裝應用清單,最好做一下預防。
- 如果使用Context.startActivity啟動外部應用,最好做一下異常預防,因為尋找不到對應的應用時,會抛出異常。如果你要打開的是應用内的Activity,不防使用顯式Intent,這樣能提高系統搜尋目标Activity的效率。
- Application的生命周期就是程序的生命周期。隻有程序被幹掉時,Application才會銷毀。哪怕是沒有Activity、Service在運作,Application也會存在。是以,為了減少記憶體壓力,盡量不要在Application裡面引用大對象、Context等。
- getWindow().setLayout(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);設定全屏方法一定要在setContentView之後
- viewpager 的 setCurrentItem 一定要在 setAdapter 方法之後調用才會有效果.
- 判斷手機是不是飛行模式
-
TabLayout 修改字型的方法 官方的 TabLayout 沒有提供修改 TextView size 的方法,可以建立一個 style CustomTabLayoutTextAppearance 繼承 TextAppearance.AppCompat.Widget.ActionBar.Title.Inverse ,然後增加 item ,設定 android:textAllCaps 為 true ,
再設定 android:textSize 為你想設定的大小。 再在 TabLayout 的布局檔案裡設定app:tabTextAppearance=”@style/CustomTabLayoutTextAppearance” 即可。
- 周遊HashMap的最佳方法
public static void printMap(Map mp) {
Iterator it = mp.entrySet().iterator();
while (it.hasNext()) {
Map.Entry pair = (Map.Entry)it.next();
System.out.println(pair.getKey() + " = " + pair.getValue());
it.remove(); // avoids a ConcurrentModificationException
}
}
- 使用Java在一個區間内産生随機整數數
public static int randInt(int min, int max) {
Random rand = new Random();
int randomNum = rand.nextInt((max - min) + ) + min;
return randomNum;
}
- 如果子類實作Serializable接口而父類未實作時,父類不會被序列化,但此時父類必須有個無參構造方法,否則會抛InvalidClassException異常。
- transient關鍵字修飾變量可以限制序列化。
- 當使用JakeWharton的TabPageIndicator時,如果需要先做一些耗時的操作,然後再展示TabPageIndicator的話,需要先設定mIndirector.setVisibility(View.GONE);然後耗時任務結束以後再mIndirector.setVisibility(View.VISIBLE);否則會報錯
- 類繼承之間的調用順序 父類static成員 -> 子類static成員 -> 父類普通成員初始化和初始化塊 -> 父類構造方法 -> 子類普通成員初始化和初始化塊 -> 子類構造方法
-
華為手機無法顯示log解決方案,.撥号界面輸入(##2846579##)
Service menu will appear.Go to “ProjectMenu” -> “Background Setting” -> “Log Setting”Open “Log switch” and set it to ON.Open “Log level setting” and set the log level you wish.
- 背景service經常因為重新開機之類的出現onStartCommand()中的Intent傳遞的參數為null, 通過在onStartCommand()中的傳回值改成return super.onStartCommand(intent, Service.START_REDELIVER_INTENT, startId); 可以解決問題。下面介紹幾個flag的意思
flag | 解釋 |
---|---|
START_STICKY | 如果service程序被kill掉,保留service的狀态為開始狀态,但不保留遞送的intent對象。随後系統會嘗試重新建立service,由于服務狀态為開始狀态,是以建立服務後一定會調用 |
onStartCommand | (Intent,int,int)方法。如果在此期間沒有任何啟動指令被傳遞到service,那麼參數Intent将為null。 |
START_NOT_STICKY | “非粘性的”。使用這個傳回值時,如果在執行完onStartCommand後,服務被異常kill掉,系統不會自動重新開機該服務。 |
START_REDELIVER_INTENT | 重傳Intent。使用這個傳回值時,如果在執行完onStartCommand後,服務被異常kill掉,系統會自動重新開機該服務,并将Intent的值傳入。 |
START_STICKY_COMPATIBILITY | START_STICKY的相容版本,但不保證服務被kill後一定能重新開機。 |
- 不能在Activity沒有完全顯示時顯示PopupWindow和Dialog
- 在多程序之間不要用SharedPreferences共享資料,雖然可以(MODE_MULTI_PROCESS),但極不穩定
- 有些時候不能使用Application的Context,不然會報錯(比如啟動Activity,顯示Dialog等)
-
謹慎使用Android的透明主題,透明主題會導緻很多問題,比如:如果新的Activity采用了透明主題,那麼目前Activity的onStop方法不會被調用;在設定為透明主題的Activity界面按Home鍵時,可能會導緻刷屏不幹淨的問題;進入主題為透明主題的界面會有明顯的延時感
不要在非UI線程中初始化ViewStub,否則會傳回null
- 盡量不要通過Application緩存資料,這不穩定
-
華為手機無法打開USB調試的問題:
插好資料線,撥号界面 輸入 ##2846579## 進入工程模式
projectmenu→3背景設定→4USB端口配置→Balong調試模式,點确定
不要拔線,退出工程模式,直接重新開機手機,電腦中顯示可移動磁盤(若仍未出現,重複步驟1、2)
這個是關閉USB調試的情況下電腦中使用手機的可移動磁盤的方法,使用後下拉菜單中usb選項也回來了。
- android listview中的消息被軟鍵盤遮擋了,在設定listview的時候加上android:transcriptMode=”normal”就好了
- TextUtils 是一個非常好用的工具類,把 List 轉成字元串,逗号分隔,逗号分隔的 String 字元串,切割成 List ,分别可以用 TextUtils 的 join 和 split 方法。如果要對 List 去重,則可以用 Collection 的 frequency 方法。
- 在activity中調用 moveTaskToBack (boolean nonRoot)方法即可将activity 退到背景,注意不是finish()退出。
- activity中的runOnUiThrea(Runnable action)方法可以直接回到主線程
- listview有個footerDividersEnabled和headerDividersEnabled方法可以設定listview的頂部和底部divide,但是必須保證你設定了headview和footview才會有效果
- Throwable類中的getStackTrace()方法,根據這個方法可以得到函數的逐層調用位址,其傳回值為StackTraceElement[];
- StackTraceElement類,其中四個方法getClassName(),getFileName(),getLineNumber(),getMethodName()在調試程式列印Log時非常有用;
- UncaughtExceptionHandler接口,再好的代碼異常難免,利用此接口可以對未捕獲的異常善後
- Resources類中的getIdentifier(name, defType, defPackage)方法,根據資源名稱擷取其ID,做UI時經常用到;
- view的isShown方法,隻有當view本身以及它的所有祖先們都是visible時,isShown()才傳回TRUE。而平常我們調用if(view.getVisibility() == View.VISIBLE)隻是對view本身而不對祖先的可見性進行判斷。
- Arrays類中的一系列關于數組操作的工具方法:binarySearch(),asList(),equals(),sort(),toString(),copyOfRange()等;Collections類中的一系列關于集合操作的工具方法:sort(),reverse()等;
- TextView類中的append(CharSequence)方法,添加文本。一些特殊文本直接用+連接配接會變成String;
- System類中的arraycopy(src, srcPos, dest, destPos, length)方法,用來copy數組;
- Fragment類中的onHiddenChanged(boolean)方法,使用FragmentTransaction中的hide(),show()時隻會調用Fragment中的show和hidden狀态,其他生命周期不會調用。
- Activity類中的onWindowFocusChanged(boolean),onNewIntent(intent)等回調方法;
- TextView類中的setTransformationMethod(TransformationMethod)方法,可用來實作“顯示密碼”功能
- PageTransformer接口,用來自定義ViewPager頁面切換動畫,用setPageTransformer(boolean, PageTransformer)方法來進行設定;
- apache提供的一系列jar包:commons-lang.jar,commons-collections.jar,commons-beanutils.jar等,裡面很多方法可能是你曾經用幾十幾百行代碼實作過的,但是執行效率或許要差很多,比如:ArrayUtils,StringUtils……;
- ActivityLifecycleCallbacks接口,用于在Application類中監聽各Activity的狀态變化 閱讀位址點我
- ActionBar.hide()/.show() 顧名思義,隐藏和顯示ActionBar,可以優雅地在全屏和帶Actionbar之間轉換。
- SystemClock.sleep() 這個方法在保證一定時間的 sleep 時很友善,通常我用來進行 debug 和模拟網絡延時。
- UrlQuerySanitizer——使用這個工具可以友善對 URL 進行檢查。
- ActivityOptions ——友善的定義兩個Activity切換的動畫。 使用ActivityOptionsCompat 可以很好解決舊版本的相容問題。
- HandlerThread,代替不停new Thread開子線程的重複體力寫法。
- IntentService,一個可以幹完活後自己去死且不需要我們去管理子線程的Service
- Executors. newSingleThreadExecutor();這個是java的,之前不知道它,自己花很大功夫去研究了單線程順序執行的任務隊列
- AsyncQueryHandler,如果做系統工具類的開發,比如聯系人短信輔助工具等,肯定免不了和ContentProvider打交道,如果資料量不是很大的情況下,随便搞,如果資料量大的情況下,了解下這個類是很有必要的,需要注意的是,這玩意兒吃異常..
- ViewFlipper,實作多個view的切換(循環),可自定義動畫效果,且可針對單個切換指定動畫。
- android util包中的Pair類,可以友善的用來存儲一”組”資料。注意不是key value
- android:descendantFocusability,ListView的item中CheckBox等元素搶焦點導緻item點選事件無法響應時,除了給對應的元素設定 focusable,更簡單的是在item根布局加上android:descendantFocusability=”blocksDescendants”
- includeFontPadding=”false”,TextView預設上下是有一定的padding的,有時候我們可能不需要上下這部分留白,加上它即可。
- EditTxt.setImeOptions, 使用EditText彈出軟鍵盤時,修改Enter鍵的顯示内容(一直很讨厭用Enter鍵來互動,是以之前一直不知道這玩意兒)
- java8中新增的LocalDate和LocalTime接口,Date雖然是個萬能接口,但是它真的不好用,有了這倆,終于可以愉快的處理日期時間了。
- WeakHashMap,直接使用HashMap有時候會帶來記憶體溢出的風險,使用WaekHashMap執行個體化Map。當使用者不再有對象引用的時候,WeakHashMap将自動被移除對應Key值的對象。
- 使用SnackBar的時候,不要使用view.getRootView()作為snackbar的view,華為榮耀7 會出問題。
- 設定TextView單行顯示的時候不要用Lines=1,而要用singleLine=”true” ,因為魅族部分手機在設定Lines=1的時候,然後TextView的值全為數字的時候, 你就會懵逼了.
- TouchDelegate可用于更改View的觸摸區域。場景:比如在RecyclerView的ItemView裡包含了CheckBox元件, 然後想實作點選ItemView的時候,也可以觸發CheckBox,就可以使用此類
- ArgbEvaluator可用于計算不同顔色值之間的插值,配合ValueAnimator.ofObject或者ViewPager.PageTransformer使用,可以實作不同顔色之間的平滑過渡。
- Palette可用于提取一張圖檔的顔色。
- ViewDragHelper,做過自定義ViewGroup的童鞋都應該知道這個東西吧,用來處理觸摸事件的神器,媽媽再也不用擔心我自定義控件了。
- PageTransformer用于定義ViewPager頁面切換時的動畫效果(淡入淡出,放大縮小神馬的…)官方有例子,直接看吧。
- Formatter.formatFileSize() 這個方法會格式化資料的大小,根據輸入的位元組大小,傳回 B KB MB GB 等等(最大支援到 PB)。當然要注意的是輸入的最大值是 Long.MAX_VALUE.
- Activity.recreate重新建立Activity。有什麼用呢?可以在程式更換主題後,立馬重新整理目前Activity,而不會有明顯的重新開機Activity的動畫。
- View.getContext顧名思義,就不用解釋了吧…以前在寫RecyclerView的Adapter的時候,為了使用LayoutInflater,經常傻乎乎地在構造函數中傳入一個外部的context….是不是隻有我不知道而已(笑cry臉)
- View.post友善在非UI線程對界面進行修改,與Handler的作用類似。并且由于post的Runnable會保證在該View繪制完成的前提下才調用,是以一般也可以用于擷取View的寬高。
- Activity.runOnUiThread與View.post類似,友善在非UI線程中對界面進行修改。
- Fragment在配合PagerAdapter使用的時候可以重寫setUserVisibleHintFragment()方法,然後根據參數的布爾值(true的話表示目前Fragment對使用者可見),來執行一些邏輯。
- android:clipToPadding 設定父view是否允許其子view在它的padding(這裡指的是父View的padding)中繪制。是不是有點繞?舉個實際場景吧:假如有個ListView,我們想要在初始位置時,第一項Item離頂部有10dp的距離,就可以在ListView的布局中加入android:clipToPadding=”false” android:paddingTop=”10dp”即可。是不是很友善呢?
- rv 的 Layoutmanager 可以直接申明在 xml 中,具體代碼可檢視RecyclerView.createLayoutManager 方法.
- RecyclerView在23.2.+的版本中新增了自動測量的功能,由于新增了自動測量,那麼它的item的根布局在需要測量的方向上就不能寫match_parent了,需要改成wrap_content
- getParent().requestDisallowInterceptTouchEvent(true);剝奪父view對touch事件的處理權,誰用誰知道。
- GradientDrawable 有個陰影效果還不錯,以為是切的圖檔,一看代碼,= =!
- 有朋友提到了在自定義View時有些方法在開啟硬體加速的時候沒有效果的問題,在API16之後确實有很多方法不支援硬體加速,通常我們關閉硬體加速都是在清單檔案中通過,其實android也提供了針對特定View關閉硬體加速的方法,調用View.setLayerType(View.LAYER_TYPE_SOFTWARE, null);即可。
- StateListDrawable,定義Selector通常的辦法都是xml檔案,但是有的時候我們的圖檔資源可能是從伺服器動态擷取的,比如很多app所謂的皮膚,這種時候就隻能通StateListDrawable來完成了,各種addState即可。
- android:duplicateParentState=”true”,讓子View跟随其Parent的狀态,如pressed等。常見的使用場景是某些時候一個按鈕很小,我們想要擴大其點選區域的時候通常會再給其包裹一層布局,将點選事件寫到Parent上,這時候如果希望被包裹按鈕的點選效果對應的Selector繼續生效的話,這時候duplicateParentState就派上用場了。
- ViewConfiguration.getScaledTouchSlop();觸發移動事件的最小距離,自定義View處理touch事件的時候,有的時候需要判斷使用者是否真的存在movie,系統提供了這樣的方法。
- ViewStub,有的時候一塊區域需要根據情況顯示不同的布局,通常我們都會通過setVisibility的方法來顯示和隐藏不同的布局,但是這樣預設是全部加載的,用ViewStub可以更好的提升性能。
- onTrimMemory,在Activity中重寫此方法,會在記憶體緊張的時候回調(支援多個級别),便于我們主動的進行資源釋放,避免OOM。
- TextView.setCompoundDrawablePadding,代碼設定TextView的drawable padding。
- ImageSwitcher,可以用來做圖檔切換的一個類,類似于幻燈片。
- 在自定義控件的時候,能用drawable來繪制圓,或者其他樣式的時候,盡量用drawable,因為drawable的效果要遠勝于canvas.drawXXX().
- 如果想要自定義View支援SwipeRefreshLayout,隻需要聲明并實作ScrollingView接口即可,RecyclerView和NestedScrollView已經實作此接口。
- AtomicFile——通過使用備份檔案進行檔案的原子化操作。這個知識點之前我也寫過,不過最好還是有出一個官方的版本比較好。
- DatabaseUtils——一個包含各種資料庫操作的使用工具。
- Activity.isChangingConfigurations ()——如果在 Activity 中 configuration 會經常改變的話,使用這個方法就可以不用手動做儲存狀态的工作了。
- SearchRecentSuggestionsProvider——可以建立最近提示效果的 provider,是一個簡單快速的方法。
- android:clipChildren (ViewGroup)——如果此屬性設定為不可用,那麼 ViewGroup 的子 View 在繪制的時候會超出它的範圍,在做動畫的時候需要用到。
- android:fillViewport (ScrollView)——在這片文章中有詳細介紹文章連結,可以解決在 ScrollView 中當内容不足的時候填不滿螢幕的問題。
- android:tileMode (BitmapDrawable)——可以指定圖檔使用重複填充的模式。
- android:enterFadeDuration/android:exitFadeDuration (Drawables)——此屬性在 Drawable 具有多種狀态的時候,可以定義它展示前的淡入淡出效果。
- Log.wtf()的意思是What a Terrible Failure,而不是What The Fuck!
- 使用RenderScript虛化圖檔效果。如果你的app的minSDK為16或者更低,你需要使用support模式,因為很多方法都是在API 17之後添加的。renderscriptTargetApi最高到23,但是你應該把它設定到能保持腳本中使用到的功能完整的最低API。如果你想在support模式下target API 21+你必須使用gradle-plugin 2.1.0 和 buildToolsVersion “23.0.3” 或者以上。需要在gradle中添加renderscriptTargetApi 18,renderscriptSupportModeEnabled true 這兩句話
public static Bitmap blurBitmap(Context context, Bitmap src, int radius) {
Bitmap dest = src.copy(src.getConfig(), true);
RenderScript rs = RenderScript.create(context);
Allocation allocation = Allocation.createFromBitmap(rs, src);
Type t = allocation.getType();
Allocation blurredAllocation = Allocation.createTyped(rs, t);
ScriptIntrinsicBlur blurScript = ScriptIntrinsicBlur.create(rs, Element.U8_4(rs));
blurScript.setRadius(radius);
blurScript.setInput(allocation);
blurScript.forEach(blurredAllocation);
blurredAllocation.copyTo(dest);
allocation.destroy();
blurredAllocation.destroy();
blurScript.destroy();
t.destroy();
rs.destroy();
return dest;
}
- 如果想把一個view儲存為Bitmap,正常情況下用第一種方法就可以了,但是如果是ScrollView,則必須采用第二種方法。
public Bitmap createViewBitmap(View v) {
Bitmap bitmap = Bitmap.createBitmap(v.getWidth(), v.getHeight(),
Bitmap.Config.ARGB_8888);
Canvas canvas = new Canvas(bitmap);
v.draw(canvas);
return bitmap;
}
/**
* 截取scrollview的螢幕
* @param scrollView
* @return
*/
public static Bitmap getBitmapByView(ScrollView scrollView) {
int h = ;
Bitmap bitmap = null;
// 擷取scrollview實際高度
for (int i = ; i < scrollView.getChildCount(); i++) {
h += scrollView.getChildAt(i).getHeight();
scrollView.getChildAt(i).setBackgroundColor(
Color.parseColor("#ffffff"));
}
// 建立對應大小的bitmap
bitmap = Bitmap.createBitmap(scrollView.getWidth(), h,
Bitmap.Config.RGB_565);
final Canvas canvas = new Canvas(bitmap);
scrollView.draw(canvas);
return bitmap;
}
- 當Activity LauncherMode 為singleTask singleInstance時,使用startActivityForResult會立馬傳回,不能正常調用。具體請看http://www.360doc.com/content/15/0123/14/12928831_443085580.shtml
- 當PopupWindow中有EditText控件時,因為Popupwindow 預設沒有擷取到焦點,需要手動設定焦點,這樣子view才能擷取到事件的監聽。是以你需要在建立完popwindow後設定他的焦點,popupWindow.setFocusable(true);就可以讓EditText擷取焦點。
- PopupWindow預設點選外部的時候不消失,需要對PopupWindow 設定一個背景圖popWindow.setBackgroundDrawable(new BitmapDrawable());要建立一個空對象,設定為null是不行的,或者就建立一個全透明的背景圖。
- android中的序列化官方推薦Parceble,其實Parceble最好用于記憶體之間資料的交換,如果要把資料寫入硬碟的話,推薦實作Serializable
- tools标簽可以很好的幫助開發者實時預覽xml的效果,并且運作以後tools标簽的内容不會展示出來.例如:
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
tools:text="這段話隻在預覽時能看到,運作以後就看不到了" />
- android studio 2.1起已經支援jdk8了,使用的時候要在gradle中加上,需要把buildToolsVersion更新到24以上的版本
android {
defaultConfig {
...
jackOptions {
enabled true
}
}
...
compileOptions {
targetCompatibility
sourceCompatibility
}
}
- 6.0之後getResources().getColor()方法被廢棄了,大家可以用ContextCompat.getColor(context, R.color.color_name)替換,ContextCompat 是 v4 包裡的,請放心使用,另外還有getDrawable()等方法
- 圖檔的資源檔案官方推薦隻把launcher放在mipmap檔案夾下面,而app用到的資源檔案建議放在drawable下面。
- SharedPreference.Editor的apply是異步操作,不會傳回成功的狀态,而commit是同步操作,是以,在多個并發的送出commit的時候,他們會等待正在處理的commit儲存到磁盤後再操作下一個資料,進而降低了效率。
- 如果你在 manifest 中把一個 activity 設定成 android:windowSoftInputMode=”adjustResize”,那麼 ScrollView(或者其它可伸縮的 ViewGroups)會縮小,進而為軟鍵盤騰出空間。但是,如果你在 activity 的主題中設定了 android:windowFullscreen=”true”,那麼 ScrollView 不會縮小。這是因為該屬性強制 ScrollView 全屏顯示。然而在主題中設定 android:fitsSystemWindows=”false” 也會導緻 adjustResize 不起作用
- 在Android 4.0以後,在Manifest.xml中靜态注冊的廣播,程式安裝後必須啟動一次才能接收到廣播,比如你的應用監聽開機啟動的廣播,必須要你的程式被運作過才能監聽到
- Activity的onDestory方法調用時機是不确定的(有時候離開界面很久之後才會調用onDestory方法),應該避免指望通過onDestory方法去釋放與Activity相關的資源,否則會導緻一些随機bug
- 2.X時代Bitmap對象雖然存儲在堆記憶體中,但是用了一個byte數組存儲其像素資訊。通過計數器來記錄該像素資訊被引用的個數。有人認為這個byte數組在native堆中,但事實上它也在堆中。隻有在使用者調用recycle()後,Bitmap對象才會釋放像素資訊,才會在失去引用後被垃圾回收機制銷毀。再加上DVM的heap size有嚴格的閥值,是以在使用大量圖檔資源的時候,及其容易發生OOM。解決辦法一般都是,用一個哈希表存儲Bitmap對象的軟引用,作為記憶體緩存,并在适當時機掉用其recycle()。3.0以上版本Bitmap對象可以通過垃圾回收機制完全銷毀,理論上不用再調用recycle()。
- .gitignore隻能忽略那些原來沒有被track的檔案,如果某些檔案已經被納入了版本管理中,則修改.gitignore是無效的。那麼解決方法就是先把本地緩存删除(改變成未track狀态),然後再送出:
git rm -r --cached .
git add .
git commit -m 'update .gitignore'
- 時間戳請使用long或者String類型接收,遇到的坑,由于項目中的model好多都是通過GsonFormat生成的,伺服器給的json中的時間戳都是10位的,導緻了GsonFormat自動解析成了int, 當測試人員選擇時間為2100年的時候時間戳是4開頭的十位 用int類型接收越界了,導緻報錯
- 為你的app添加預設布局樣式,比如:每一個控件都需要寫width和height屬性,然而很多的控件的寬高屬性都是wrap_content,那麼我們可以通過在style檔案添加如下樣式:
<style name="Theme.YourApp" parent="android:style/Theme.Light">
<item name="android:layout_width">wrap_content</item>
<item name="android:layout_height">wrap_content</item>
</style>
這樣,控件的寬高預設都是wrap_content樣式啦。
- 在style中寫的樣式通過視同parent标簽來擴充你的樣式,這樣更高效。
<style name="Fill">
<item name="android:layout_width">fill_parent</item>
<item name="android:layout_height">fill_parent</item>
</style>
<style name="Fill.Height" parent="@style/Fill">
<item name="android:orientation">vertical</item>
</style>
- Android上的應用切換按鈕列出的其實不是應用而是Task,是以你會看到有的應用在切換視圖裡有多個任務。如果你的應用中有邏輯上互相獨立的部分,或者想在多視窗環境下并排顯示應用的兩個不同部分,這種情況就适合多任務了。使用manifest屬性(靜态)或者 intent flags(動态)可以實作這一點,詳見視訊: http://v.youku.com/v_show/id_XMTU2ODk4NDg2NA==.html?f=26587294
- 當app的theme用的是NoActionBar,但是在layout中仍然用到toolbar的時候,不要在style檔案中加fitsSystemWindows屬性,而是在用到toolbar的layout最外層加fitsSystemWindows,否則當你使用EditText,在小米手機上長按EditText調出系統粘貼功能的時候,粘貼的layout的布局會錯位.
- 當WebView與ScrollView嵌套使用,并且WebView有字型放大縮小的功能時,當切換webview的字型後,webview的高度并不能很好的計算出來,這時候可以通過注入的方式,讓js算出高度,經測試,這樣是最可靠的,代碼位址:http://blog.csdn.net/jys1115/article/details/43525979
- Context類中的createPackageContext(packageName, flags)方法,可用來擷取指定包名應用程式的Context對象。
- TextView類的setKeyListener(KeyListener)方法; 其中DigitsKeyListener類,使用getInstance(String accepted)方法即可指定EditText可輸入字元集;
- View類中的getLocationInWindow(int[])方法和getLocationOnScreen(int[])方法,擷取View在視窗/螢幕中的位置;
- Context.getCacheDir() - 可以擷取到app預設的緩存路徑。
- StaticLayout 在自定義控件繪制文本的時候很有用。
摘自如下位址(部分):
http://oakzmm.com/2015/08/04/cool-Android-api/
http://oakzmm.com/2015/08/11/cool-Android-api-2/
http://weibo.com/liangfeizc?from=feed&loc=nickname
http://zhuanlan.zhihu.com/zmywly8866/20309921
http://www.zhihu.com/question/33636939
http://gold.xitu.io/entry/56c2b9b779bc4400540894ac
https://www.zhihu.com/question/33636939/answer/57239990?group_id=612750833369153536
http://mp.weixin.qq.com/s?__biz=MzA4MTM2MjE2MA==&mid=2650836293&idx=3&sn=2624066ababb6b613634015f54ea19b6&scene=0#wechat_redirect
http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2016/0504/4205.html
https://zhuanlan.zhihu.com/p/20309921
http://www.pfeng.org/archives/840#123-tsina-1-92600-1bb80a0982f5c2ea1fcaf67d7fdce2f1
http://blog.danlew.net/2014/03/30/android-tips-round-up-part-1/