中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

安卓編程小tips

發布時間:2020-07-31 10:38:39 來源:網絡 閱讀:318 作者:1111565464 欄目:移動開發

http:://developer.android.com/design/index.html  //design guideline

xmlns:android = "http://schema.android.com/apk/res/android"

0、時刻記得維護好你的AndroidManifest.xml,很多錯誤就是它搞的...

     所有擁有id的View都能在橫豎屏切換等變換之后保留其狀態。

    Refactor->Extract->Method能將代碼提取為方法。

1、將所有的String放到values/string.xml文件中

2、public static Toast makeText ( Context context, int resId, int duration )

    其中第一個,如果是在監聽器的匿名類中,記住不能直接this,而是activity.this,因為此時的this是指該匿名類

3、MVC

M:modle  此層封裝、管理數據對象,一般用class(p.s. UUID可以產生不重復的id)

C :controller 此層連接二者,是應用的邏輯層。處理view發送來的用戶行為,再在modle中做相應的操作,包括數據的更改以及傳輸。一般是Activity啥的Java文件

V : view  此層處理視圖界面,以及對用戶行為的反應(比如點擊事件),一般是從layout.xml 布局文件中加載來的

4、在變量的命名傳統中,我們一般加上前綴m,對于static變量,一般加上前綴s

5、圖片、xml文件資源名字必須小寫

6、在生命周期的方法里邊,注意先super.XXX()再做其他事情

7、Activity生命周期

    由OS掌控,在paused(仍然可見)或者stopped的狀態下有可能被回收掉,這時候onSaveInstanceState(...)就會被調用,這個Bundle是被OS記錄下來的(activity record),這個activity record會存留在OS中,即使整個應用都已經被kill掉了。只有在用戶按下Back(用戶自己想關閉)、手機Reboot或者說隔了很長很長時間時,這個activity record也會被扔掉。

8、調試

    1. 直接看報錯,調到錯誤處

    2. 在你覺得有問題的函數里邊,使用Log.d(String tag, String message, Throwable) , 第三個參數直接new Exception(),這樣的話在logcat中能顯示你是在哪里調用這個函數的(但要注意不要在太多地方用,否則logcat會爆炸)

    3. 使用斷點

    4. 使用Lint,這個很厲害的

    5. 當R文件出錯冒紅時,嘗試一下方法

        1. 檢查xml文件中有沒有打錯字啥的

        2. Build -> Clean Project 或者 Sync Project

        3. 好好看看Lint的警告

        4. 棄療.......

9、 開啟新的Activity時使用被開啟的Activity的public static 函數

    e.g.    

        public static Intent newIntent(Context fromContext, Bundle data)

        {

            Intnet intent = new Intent(fromContext, selfActivity.class);

            intent.putExtras(data);//如果沒用到bundle,需要傳入key,也是在被打開的Activity處聲明private static final的String key,記得在Activity的開頭處寫明需要什么參數及其用途

            return intent;

        }

        有返回值的也是類似

10、在橫豎屏切換的時候,若橫豎屏的控件啥的不一樣,記住在代碼中要進行判斷(該控件是否為空,etc)

11、ActivityManager管理一個Activity的棧,存在于OS中,在它看來任何應用中的Activity都是一樣的

12、版本兼容控制

在app/build.gradle,更改后需要Sync一下gradle(一般似乎也是會自動Sync的)

    Minimum SDK version:設備的版本低于它時,拒絕安裝(當使用高于此版本的功能時,一般Lint是會提醒的)

    Target SDK version:顧名思義

    Compile SDK version:這個決定了Compiler用的是什么版本的SDK

判斷版本是否滿足要求:

    if(Build.VERSION.SDK_INT >= bUILD.VERSION_CODES.LOLLIPOP)

    {...}//前者為設備的版本,第二個為用到的功能的版本,具體要看是哪個功能(目前最新為LOLLIPOP


13、關于Fragment

    1. 所有界面(包括M與V的連接)都用Fragment來寫,不要用Activity(繼承自FragmentActivity,它只用于把Fragment召喚出來,而Fragment的生命周期也是由Activity掌控的,一般用FrameLayout來做container),原因:不這樣強迫自己,你永遠不會想要去用Fragment的,因為它確實很蛋疼——一個Activity不要使用超過3個Fragment,否則你的代碼會亂得讓你分分鐘想自行了斷(小的組成部分直接用控件就好了)


    2. 用android.support.v4.app.Fragment而不是內置的那個(android.app.Fragment),因為support庫更新更快。注意要用support library的話,需要在Project Structure哪里添加dependency。(v4的4說明支持的最低版本是4,而Fragment本身是到API 11才出來的,這也說明用support library的話向前兼容性更強)


    3. 一個Fragment同樣包含一個layout文件和一個Java文件(繼承自Fragment,有倆版本,別選錯),跟Activity很像,而且Fragment也是有onSaveInstanceState(Bundle)的。FragmentManager用getSupportFragmentManager()。


    4. 其生命周期基本上是與Activity的一樣的

        public View onCreatView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)

            第二個參數是放置該Fragment的容器。

        LayoutInflater.inflate(...)

            第一個參數是布局文件的id,第二個是container,第三個是選擇是否在此時就把這個Fragment給放上去(一般選false,因為我們是動態地放上去的)


    5. 可以用fragmentManager.findFragmentById(container)來找出這個容器里放置的Fragment。


    6. 當重復性的創建開啟fragment(或者其他事情)的時候,考慮創建一個abstract class,這樣簡潔很多


    7. 兩個Activity之間的Fragment的傳值可以:

        1. 直接借助其寄居的Activity來實現,用getActivity(),但是這樣的話,接受值的Fragment必須要使用其寄居的Activity的key才能獲取,這樣破壞了Fragment的encapsulation;

        2. 這種方法適用于任意兩個Fragment(一個或兩個Activity中皆可),我們將使用Fragment的argument。在接受參數的Fragment的構造函數中,就規定好要傳入一個bundle,調用Fragment.setArguments(Bundle),然后返回該Fragment實例。取出時則用getArguments()。


    8. 同一個Activity之間的Fragment的傳值可以:

        1. 仍然是使用Intent,以及Fragment.onActivityResult(...)。

        2. 在第一個Fragment中就掉用第二個Fragment的setTargetFragment(第一個.this,requestCode),將第二個目標制定為自己,這個很像startActivityForResult(...)。而在第二個Fragment中將結果發送回來時要自己手動調用getTargetFragment().onActivityResult(getTargetRequestCode(),resultCode,intent);


14、dp是density-independent pixel,即大小是一定的;

        sp是scale-independent pixel,多考慮了user的字體大小,所以一般用它來描述text的size

        

15、先把同一級控件都分配好空間,剩下的控件再用于layout_weight的分配


16、使用單例模式是很好的。將類的constructor設為private,只在類的public static的獲取單例的函數中調用。當然啦,這個單例就是我們的類,要設為private static的。但是不要濫用單例來存儲全局變量,什么都放進去會讓你的代碼跟shi一樣,讓人搞不懂你那變量是用在哪里干什么的,也就是說破壞了封裝性。


17、RecyclerView:一個很棒的呈現列表的東西。它能回收利用資源,比如說,我們要展示100個item,那我們其實沒必要為100個item都創建View,只需要屏幕上呈現的那些有View就好了——RecyclerView就給我們做到了這點,它回收利用那些已經跑出屏幕的那些item的View (實際上ListView也可以回收,但是太老了,而且不靈活,無動畫,修改數據很麻煩)

    ViewHolder:作為item的View的存放者

        e.g.

            public class ListItemHolder extends RecyclerView.ViewHolder

            {

                public ImageView mPicture;


                public ListItemHolder(View itemView)//這里這個View就是由Adapter給的,布局文件

                {

                    super(view);

                    mPicture = (ImageView)itemView.findViewById(R.id.xxx);

                }

            }

    

    Adapter:作為RecyclerView與其所展示的data之間的Controller,它做了兩點:一是create the necessary ViewHolders,二是將ViewHolder與modle層的數據相連接。類的定義是:private class xxxAdapter extends RecycleView.Adapter<Holder>{...}作為RecycleView的內部類.

    當數據被改動需要重新加載時,使用Adapter.notifyDataSetChanged(),但這個是全部加載;使用notigyItemChanged(int position)就只更新一個。


    首先,RecyclerView向Adapter詢問一共多少項,getItemCount();接著,它調用Adapter的createViewHolder(ViewGroup parent,int)創建一個ViewHolder以及一個要展示的view(如果要自定義View的話就在這里把布局文件傳進去,

    return new xxxViewHolder( LayoutInflater.from( getActivity() ).inflater(布局,parent ,false);

此時view中尚未有數據),當create出來的ViewHolder足夠用時,就不再create了,回收即可;最后,它調用了onBindViewHolder(ViewHolder,int position),然后Adapter根據這個position找到數據將其填充到剛剛那個view中去。

    注意,RecyclerView在使用前必須先調用setLayoutManager(...),否則崩潰。這個LayoutManager就是被叫來把item放到合適位置上的。


18、ViewPager

    不使用FrameLayout了,轉用ViewPager來承載Fragment。ViewPager也是需要配置Adapter的,一般使用PagerAdapter的子類FragmentStatePagerAdapter(其構造函數需要傳入一個FragmentManager作為參數...),并重寫getCount()和getItem(int)——返回一個Fragment  這兩個方法。

    找到你要展示的那一項,然后調用ViewPager.setCurrentItem(int index),否則每次都從頭開始。


    當你想要讓ViewPager顯示非Fragment的時候,你就需要自己實現PagerAdapter了。主要是3個方法:

        1、public Object instantiateItem(ViewGroup container, int position)

        2、public void destroyItem(ViewGroup container, int position, Object object)

        3、public abstract boolean isViewFromObject(View view, Object object)


19、AlertDialog(Dialog.AlertDialog的一個子類)

    最好是將這個AlertDialog作為一個DialogFragment來實現(這樣的話能將這個Dialog交給FragmentManager去管理,切換屏幕方向什么的之后它也能被重新create)——重寫其onCreateDialog(Bundle)方法。再顯現這個DialogFragment的時候,要調用其實例的show(FragmentManager,String tag)方法。如果使用onCreateView(Bundle),則需要自己實現全部布局,但是可以使用startActivityForResult(...)來傳參。

    在Dialog中調用setView(View),可以設置Dialog中間部分的視圖。


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

那坡县| 柏乡县| 新干县| 从江县| 成安县| 新泰市| 云霄县| 莱州市| 张家川| 鞍山市| 都昌县| 城固县| 珠海市| 灵璧县| 英吉沙县| 云龙县| 文成县| 治多县| 自贡市| 涟水县| 木里| 九台市| 凤阳县| 小金县| 建昌县| 大新县| 吴川市| 梧州市| 南木林县| 辽阳县| 钟祥市| 宁陵县| 凤庆县| 勐海县| 镇平县| 宝丰县| 顺昌县| 明光市| 铜鼓县| 西乌珠穆沁旗| 古交市|