主頁 > 軟體設計 > Android基礎知識——開發中遇到的問題

Android基礎知識——開發中遇到的問題

2020-10-20 07:25:29 軟體設計

文章目錄

  • 1.動態控制布局的位置
  • 2.單選按鈕的使用
  • 3.僅在需要時才顯示布局
    • 3.1控制布局的可見屬性
    • 3.2ViewStub
    • 3.3以上兩種方法的利弊
  • 4.判斷ImageView展示的是哪一張圖片
  • 5.單選框的使用
  • 6.RecyclerView實作側滑洗掉
  • 7.在活動中處理RecyclerView的點擊事件

1.動態控制布局的位置

在開發時,我們可能需要在同一活動中的不同界面下來改變布局的位置使得布局處于一個比較合理的位置,

例如:我們在活動的主界面希望用戶能有沉浸式的體驗,所以我們將我們的布局延伸到了系統欄中,可是當我們轉換到設定(碎片)的界面時,就很有可能發生系統欄中的圖示,將我們界面上標題欄的部分按鈕遮擋的情況,而為了解決這一問題我們就要在代碼中對布局位置進行控制了,

代碼展示:

FrameLayout.LayoutParams layoutParams;
layoutParams=(FrameLayout.LayoutParams) view.findViewById(R.id.choose_layout).getLayoutParams();
if(getActivity() instanceof WeatherActivity){
    //動態控制布局的margin屬性
    layoutParams.topMargin=50;
}

2.單選按鈕的使用

在開發時,很多時候都會讓用戶選擇讓某一項功能開啟還是關閉,這個時候就需要一個比較美觀的控制元件來實作這一功能了,

效果展示:

代碼展示:

//宣告依賴
dependencies {
    implementation 'com.github.zcweng:switch-button:0.0.3'
}
//布局檔案中用法
<com.suke.widget.SwitchButton
    android:id="@+id/switch_button"
    android:layout_gravity="center"
    android:layout_marginLeft="60dp"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content" />
//邏輯檔案中用法
switchButton.setChecked();//設定控制元件的開關狀態
switchButton.setOnCheckedChangeListener(new SwitchButton.OnCheckedChangeListener() {
    @Override
    public void onCheckedChanged(SwitchButton view, boolean isChecked) {//點擊事件
        if(isChecked==true){
            //當控制元件變為true時的邏輯代碼
        }else if(isChecked==false){
            //當控制元件變為false時的邏輯代碼
        }
    }
});

3.僅在需要時才顯示布局

在開發時,我們可能會需要先隱藏部分布局,然后當用戶執行某一操作后再將這部分布局顯現出來,為了實作這一功能我給大家介紹兩種方法,并為大家指出它們的利弊,

3.1控制布局的可見屬性

我們需要先將需隱藏布局的可見屬性設定為View.GONE,然后在用戶執行某一操作后將可見屬性設定為View.VISIBLE即可輕易實作這一功能,

3.2ViewStub

我們也可以使用ViewStub控制元件來幫助我們實作這一功能,

代碼展示:

//待隱藏布局
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >
 
    <EditText
        android:id="@+id/edit_extra1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginLeft="20dp"
        android:layout_marginRight="20dp"
        android:hint="Extra field 1" />
 
    <EditText
        android:id="@+id/edit_extra2"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginLeft="20dp"
        android:layout_marginRight="20dp"
        android:layout_marginTop="10dp"
        android:hint="Extra field 2" />
 
    <EditText
        android:id="@+id/edit_extra3"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginLeft="20dp"
        android:layout_marginRight="20dp"
        android:layout_marginTop="10dp"
        android:hint="Extra field 3" />
 
</LinearLayout>
//主界面布局
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >
 
    <EditText
        android:id="@+id/edit"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginBottom="10dp"
        android:layout_marginLeft="20dp"
        android:layout_marginRight="20dp"
        android:layout_marginTop="10dp"
        android:hint="@string/edit_something_here" />
 
    <Button
        android:id="@+id/more"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="right"
        android:layout_marginRight="20dp"
        android:layout_marginBottom="10dp"
        android:text="More" />
    
    <ViewStub 
        android:id="@+id/view_stub"
        android:layout="@layout/profile_extra"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />
 
</LinearLayout>
//邏輯代碼
private EditText editExtra1;
private EditText editExtra2;
private EditText editExtra3;

public void onMoreClick() {//當我們點擊more按鈕時執行該函式,即可是實作隱藏布局的顯示
	ViewStub viewStub = (ViewStub) findViewById(R.id.view_stub);
	if (viewStub != null) {
		View inflatedView = viewStub.inflate();
		editExtra1 = (EditText) inflatedView.findViewById(R.id.edit_extra1);
		editExtra2 = (EditText) inflatedView.findViewById(R.id.edit_extra2);
		editExtra3 = (EditText) inflatedView.findViewById(R.id.edit_extra3);
	}

3.3以上兩種方法的利弊

第一種方法:

  • 優點:邏輯簡單而且控制起來比較靈活,

  • 缺點:耗費資源,雖然把View的初始可見View.GONE但是在Inflate布局的時候View仍然會被Inflate,也就是說仍然會創建物件,會被實體化,會被設定屬性,也就是說,會耗費記憶體等資源,

第二種方法:

  • 優點:在Inflate布局的時候,只有ViewStub會被初始化,然后當ViewStub被設定為可見的時候,或是呼叫了ViewStub.inflate()的時候,ViewStub所向的布局就會被Inflate和實體化,然后ViewStub的布局屬性都會傳給它所指向的布局,這樣,就可以使用ViewStub來方便的在運行時,要還是不要顯示某個布局,這樣也就節省了記憶體資源,實作了布局的優化,

  • 特點:ViewStub只能Inflate一次,之后ViewStub物件會被置為空,也就是說,某個被ViewStub指定的布局被Inflate后,就不能再通過ViewStub來控制它了;ViewStub只能用來Inflate一個布局檔案,而不是某個具體的View,當然也可以把View寫在某個布局檔案中,

  • 缺點:在程式的運行期間,某個布局在Inflate后,就不會有變化,除非重新啟動,也就是說,不能再將加載出來的布局隱藏了;只能控制顯示與隱藏的是布局檔案,而非某個View,

4.判斷ImageView展示的是哪一張圖片

在開發時,我們有可能要根據ImageView展示的圖片,來決定讓其執行哪一點擊事件,而要實作這一功能就需要判斷先ImageView展示的是哪一張圖片,

代碼展示:

moreImage.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View view) {
        if(moreImage.getDrawable().getCurrent().getConstantState().equals(ContextCompat.getDrawable(SettingActivity.this,R.drawable.many).getConstantState())){//判斷方法
            //具體邏輯
        }else {
            //具體邏輯
        }
    }
});

5.單選框的使用

在開發時,我們有時需要提供一組選項,來讓用戶選擇一個,而實作這一功能就要利用單選框控制元件了,

代碼展示:

//布局檔案
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    
    <RadioGroup
        android:id="@+id/radio_group"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">

        <RadioButton
            android:id="@+id/eight_time"
            android:layout_margin="10dp"
            android:text="8小時"
            android:textSize="20sp"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />

        <RadioButton
            android:id="@+id/four_time"
            android:layout_margin="10dp"
            android:text="4小時"
            android:textSize="20sp"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />

        <RadioButton
            android:id="@+id/two_time"
            android:layout_margin="10dp"
            android:text="2小時"
            android:textSize="20sp"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />

        <RadioButton
            android:id="@+id/one_time"
            android:layout_margin="10dp"
            android:text="1小時"
            android:textSize="20sp"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />

    </RadioGroup>

</LinearLayout>
//邏輯代碼
radioGroup.check();//設定哪一單選框為選中狀態
radioGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {//點擊事件
    @Override
    public void onCheckedChanged(RadioGroup radioGroup, int i) {
        switch (i){
            case R.id.eight_time:
                //選中后的邏輯代碼
                break;
            case R.id.four_time:
                //選中后的邏輯代碼
                break;
            case R.id.two_time:
                 //選中后的邏輯代碼
                break;
            case R.id.one_time:
                 //選中后的邏輯代碼
                break;
            default:
        }
    }
}

6.RecyclerView實作側滑洗掉

在開發中,我們有時需要實作側滑RecyclerView的某一子項布局來洗掉它的功能,

以下代碼中省略了RecyclerView的基本實作方法,倘若有讀者還不太清楚,請移步這里

代碼展示:

//為RecycleView系結觸摸事件
ItemTouchHelper helper=new ItemTouchHelper(new ItemTouchHelper.Callback() {

    @Override
    public int getMovementFlags(@NonNull RecyclerView recyclerView, @NonNull RecyclerView.ViewHolder viewHolder) {
    	//首先回呼的方法 回傳int表示是否監聽該方向
        int dragFlags = ItemTouchHelper.UP|ItemTouchHelper.DOWN;//拖拽
        int swipeFlags = ItemTouchHelper.LEFT|ItemTouchHelper.RIGHT;//側滑洗掉
        return makeMovementFlags(dragFlags,swipeFlags);
    }
    
    @Override
    public boolean onMove(@NonNull RecyclerView recyclerView, @NonNull RecyclerView.ViewHolder viewHolder, @NonNull RecyclerView.ViewHolder target) {
    	//滑動事件
        return false;
    }
    
    @Override
    public void onSwiped(@NonNull RecyclerView.ViewHolder viewHolder, int direction) {
    	//側滑事件
        nameList.remove(viewHolder.getAdapterPosition());
        myAdapter.notifyItemRemoved(viewHolder.getAdapterPosition());
    }
    
});
helper.attachToRecyclerView(recyclerView);

注意:倘若你還需在側滑事件中洗掉資料庫的內容,要將其放在remove函式之前,否則getAdapterPosition()的回傳值會發生變化,

7.在活動中處理RecyclerView的點擊事件

當我們在處理RecyclerView的點擊事件時很有可能還要用到活動中的一些資料,而一般情況下RecyclerView的點擊事件是在其配接器中注冊的,這就使得你可能無法在點擊事件中實作某些功能了,而為了解決在活動中處理點擊事件這一問題,我們可以利用回呼介面來實作,

代碼展示:

//定義介面
public interface OnItemClickListener {
    void onItemClick(int position);
}
//在配接器的點擊事件中呼叫該介面中的方法
public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> {

    private List<Saved> list=new ArrayList<>();
    private OnItemClickListener Listener=null;
    
    public MyAdapter(List<Saved> list, OnItemClickListener Listener){//我們還需要在構造方法傳入該介面
        this.Listener=Listener;
        this.list=list;
    }
    
    @NonNull
    @Override
    public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, final int viewType) {
        View view= LayoutInflater.from(parent.getContext()).inflate(R.layout.recycler_item,parent,false);
        final ViewHolder viewHolder=new ViewHolder(view);
        view.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Listener.onItemClick(viewHolder.getAdapterPosition());//呼叫介面中的方法
            }
        });
        return viewHolder;
    }

	......
}
//在活動中實作該介面中的方法
OnItemClickListener recyclerListener=new OnItemClickListener() {
    @Override
    public void onItemClick(int position) {
        //具體邏輯代碼
    }
};

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/181707.html

標籤:其他

上一篇:android github 開源的圖片剪輯庫使用效果記錄

下一篇:Android和java知識點總結

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more