Android頁(yè)面中可編輯與不可編輯切換的實(shí)現(xiàn)
前言
相信大家在開(kāi)發(fā)中經(jīng)常遇到這樣的需求,我們?cè)谀骋豁?yè)面,點(diǎn)擊某可按鈕后,需要把顯示的頁(yè)面變?yōu)榭删庉嫷捻?yè)面,以便修正數(shù)據(jù),這樣的頁(yè)面該怎么實(shí)現(xiàn)呢?
先看截圖
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/all_views" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" tools:context=".MainActivity"> <Button android:id="@+id/edit" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="編輯" android:textSize="25sp" /> <RadioGroup android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <RadioButton android:id="@+id/boy" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="男" android:textSize="25sp" /> <RadioButton android:id="@+id/girl" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="女" android:textSize="25sp" /> </RadioGroup> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_weight="1"> <EditText android:id="@+id/views" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@null" android:hint="代表一大堆控件" android:textSize="25sp" /> </LinearLayout> <Button android:id="@+id/special" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="一個(gè)在編輯狀態(tài)和不可編輯狀態(tài)都要用的Button" android:textSize="25sp" /> </LinearLayout>
活動(dòng) MainActivity.java:
public class MainActivity extends AppCompatActivity implements View.OnClickListener { Button edit, special; LinearLayout linearLayout; RadioButton boy, girl; EditText views; List<View> viewList = new ArrayList<>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); edit = (Button) findViewById(R.id.edit); special = (Button) findViewById(R.id.special); linearLayout = (LinearLayout) findViewById(R.id.all_views); edit.setOnClickListener(this); special.setOnClickListener(this); boy = (RadioButton) findViewById(R.id.boy); girl = (RadioButton) findViewById(R.id.girl); views = (EditText) findViewById(R.id.views); viewList.add(boy); viewList.add(girl); viewList.add(views); setViewsEnable(false); } @Override public void onClick(View v) { if (v.getId() == R.id.edit) { if (edit.getText().toString().equals("編輯")) { edit.setText("完成"); setViewsEnable(true); } else { edit.setText("編輯"); setViewsEnable(false); } } else if (v.getId() == R.id.special) { Toast.makeText(this, "我總是有用的那個(gè)", Toast.LENGTH_SHORT).show(); } } private void setViewsEnable(boolean able) { for (View view : viewList) { view.setEnabled(able); view.setFocusable(able); } } }
這樣基本的要求達(dá)到了,但是還有個(gè)問(wèn)題:EditText不能輸入了 !,就上述代碼,id為views的EditText無(wú)論在那種狀態(tài)都不能輸入了。
點(diǎn)擊兩次才響應(yīng)和EditText不能輸入問(wèn)題
將其中方法改動(dòng):
private void setViewsEnable(boolean able) { for (View view : viewList) { view.setEnabled(able); view.setFocusable(able); view.setFocusableInTouchMode(able); } }
做出如上改動(dòng)后,輸入問(wèn)題倒是解決了,可是控件必須點(diǎn)擊兩次才響應(yīng),那么對(duì)比之前可以推測(cè),屬性:
setFocusableInTouchMode導(dǎo)致了該問(wèn)題,既然添加了該屬性后EditText正常,其他控件不正常,那么區(qū)別對(duì)待之,另做如下修改:
private void setViewsEnable(boolean able) { for (View view : viewList) { view.setEnabled(able); view.setFocusable(able); if (view instanceof EditText) { view.setFocusableInTouchMode(able); } } }
如此,我們的目標(biāo)達(dá)到了,只是,正常情況下,我們這個(gè)頁(yè)面可能有十幾個(gè)、甚至幾十個(gè)控件需要操作,那么我們一個(gè)個(gè)找到之再添加到viewList中,丑不丑陋不好說(shuō),反正是搞得眼花繚亂就是,作為一個(gè)有抱負(fù)的碼農(nóng)果斷不能忍!
更優(yōu)雅的方式
既然問(wèn)題是出在控件太多,一個(gè)個(gè)添加要操作控件太麻煩,那么可不可以遍歷布局尋找控件呢,可以的,將活動(dòng)代碼做如下修改:
package com.example.softdk.myapplication; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.util.Log; import android.view.View; import android.view.ViewGroup; import android.widget.Button; import android.widget.EditText; import android.widget.LinearLayout; import android.widget.RadioButton; import android.widget.Toast; import java.util.ArrayList; import java.util.List; public class MainActivity extends AppCompatActivity implements View.OnClickListener { Button edit, special; LinearLayout allViews; RadioButton boy, girl; EditText views; List<View> viewList = new ArrayList<>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); edit = (Button) findViewById(R.id.edit); special = (Button) findViewById(R.id.special); allViews = (LinearLayout) findViewById(R.id.all_views); edit.setOnClickListener(this); special.setOnClickListener(this); traversalView(allViews); setViewsEnable(false); } @Override public void onClick(View v) { if (v.getId() == R.id.edit) { if (edit.getText().toString().equals("編輯")) { edit.setText("完成"); setViewsEnable(true); } else { edit.setText("編輯"); setViewsEnable(false); } } else if (v.getId() == R.id.special) { Toast.makeText(this, "我總是有用的那個(gè)", Toast.LENGTH_SHORT).show(); } } private void traversalView(ViewGroup viewGroup) { int i = viewGroup.getChildCount(); for (int j = 0; j < i; j++) { View view = viewGroup.getChildAt(j); if (view.getId() == R.id.edit) continue;//除去我們 編輯-完成 按鈕,正常使用情況下一般是在標(biāo)題欄上添加監(jiān)聽(tīng),不會(huì)有這個(gè)情況= else if (view.getId() == R.id.special) continue;//除去那些我們?cè)?編輯-完成 狀態(tài)都需要起作用的按鈕 viewList.add(view);//找所有布局和控件 if (view instanceof ViewGroup) { /** * viewList.add(view);//只找布局 * * 注意此處,如果該空間是布局容器,那么繼續(xù)尋找布局內(nèi)部的控件 * 直到找到的控件不是布局容器 * 如果我們想找的控件包括了布局容器(如LinearLayout之類(lèi)的里面能放控件的東西) * 那么應(yīng)該在該判讀之前將找到的view添加到我們的集合 * 如果僅僅是想找控件,那么在else之內(nèi)添加(下面注釋掉了) */ traversalView((ViewGroup) view); } else { // viewList.add(view);//只找控件 } } } private void setViewsEnable(boolean able) { for (View view : viewList) { view.setEnabled(able); view.setFocusable(able); if (view instanceof EditText) { view.setFocusableInTouchMode(able); } } } }
不賣(mài)關(guān)子了,上面就是完整版,去掉注釋?zhuān)壿嬤€是很簡(jiǎn)單清晰的,如果結(jié)合Butterknife等框架插件使用的話,能大大減少瑣碎代碼的編寫(xiě)。注意看下那兩句continue其實(shí)一個(gè)意思,除去我們想讓它一直發(fā)揮作用的控件,其實(shí)還有一種方法是:
將我們需要改變狀態(tài)的控件放到一個(gè)類(lèi)似于文中id為all_views的布局中,然后遍歷該布局容器即可,這種做法對(duì)那些總是發(fā)揮作用的控件集中在一起的話(比如都在頁(yè)面下半部分),還是比較方便的。
而文中做法勝在靈活,可以對(duì)任意控件做特殊操作。這部分就到這兒吧,希望能對(duì)你有用。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
用Flutter做桌上彈球(繪圖(Canvas&CustomPaint)API)
這篇文章主要介紹了用Flutter做桌上彈球 聊聊繪圖(Canvas&CustomPaint)API,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07Android開(kāi)機(jī)自啟動(dòng)程序詳解
本篇文章是對(duì)Android開(kāi)機(jī)自啟動(dòng)程序進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06Android實(shí)現(xiàn)zip文件壓縮及解壓縮的方法
這篇文章主要介紹了Android實(shí)現(xiàn)zip文件壓縮及解壓縮的方法,涉及Android針對(duì)文件的遍歷及zip壓縮與解壓縮的實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07詳解Android Service與Activity之間通信的幾種方式
這篇文章主要介紹了詳解Android Service與Activity之間通信的幾種方式,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-04-04Android自定義View的使用及其原理知識(shí)點(diǎn)總結(jié)
在本篇文章里小編給大家整理的是關(guān)于Android自定義View的使用及其原理知識(shí)點(diǎn)總結(jié)內(nèi)容,需要的朋友們可以學(xué)習(xí)下。2019-08-08