Android 는 로그 인 페이지 로고 가 키보드 에 따라 동적 신축 을 실현 합 니 다(키보드 팝 업 차단 컨트롤 문 제 를 완벽 하 게 해결 합 니 다)

최근 의 두 가지 프로젝트 에서 프로젝트 수 요 는 우리 에 게 실현/*로그 인 페이지 의 내용 이 키보드 의 팝 업 에 따라 위로 올 라 가 키보드 가 로그 인 버튼 을 가리 지 않도록 해 야 한다.
그럼 하 세 요.초보 적 으로 정 한 방안 은 입력 상자 와 로그 인 버튼 의 크기 가 변 하지 않 고 키보드 가 꺼 질 때 로고 의 크기 와 위 치 를 바 꾸 어 키보드 에 위 치 를 비 워 주 는 것 입 니 다.물론 키보드 가 꺼 질 때 복원 해 야 합 니 다.아무 일 도 없 었 던 것 처럼.네,그렇습니다.이렇게 많은 말 을 했 습 니 다.그림 을 놓 고 먼저 효 과 를 느껴 보 세 요.

그 다음 에 정식 을 먹 으 면 구조 가 비교적 간단 합 니 다.그림 바깥쪽 에 몸 에 맞 는 linearlayout 을 끼 워 주면 됩 니 다.이따가 로고 의 위 치 를 바 꿔 야 하기 때문에 구조 코드 는 다음 과 같 습 니 다.

<?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:layout_width="match_parent" 
 android:layout_height="match_parent" 
 android:background="@color/white" 
 tools:context=".login.LoginActivity" 
 android:orientation="vertical" 
 android:id="@+id/ll_login_root"> 
 <LinearLayout 
  android:orientation="vertical" 
  android:layout_width="match_parent" 
  android:layout_height="wrap_content" 
  android:layout_marginTop="90dp" 
  android:id="@+id/ll_login_logobg" 
  android:layout_marginBottom="50dp"> 
  <ImageView 
   android:layout_width="160dp" 
   android:layout_height="160dp" 
   android:id="@+id/iv_login_logo" 
   android:background="@mipmap/login_logo" 
   android:layout_gravity="center_horizontal" /> 
 </LinearLayout> 
 <LinearLayout 
  android:orientation="vertical" 
  android:layout_width="match_parent" 
  android:layout_height="match_parent" 
  android:layout_marginLeft="50dp" 
  android:layout_marginRight="50dp"> 
  <LinearLayout 
   android:orientation="horizontal" 
   android:layout_width="match_parent" 
   android:layout_height="50dp"> 
   <ImageView 
    android:layout_width="45dp" 
    android:layout_height="45dp" 
    android:background="@mipmap/login_phone" 
    android:id="@+id/imageView2" 
    android:layout_gravity="bottom" /> 
   <EditText 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:inputType="phone" 
    android:ems="10" 
    android:id="@+id/et_login_phone" 
    android:layout_gravity="center" 
    android:hint="      " 
    android:background="@null" 
    android:maxLength="11"/> 
  </LinearLayout> 
  <LinearLayout 
   android:orientation="vertical" 
   android:layout_width="match_parent" 
   android:layout_height="1dp" 
   android:background="@color/text_gray"></LinearLayout> 
  <LinearLayout 
   android:orientation="horizontal" 
   android:layout_width="match_parent" 
   android:layout_height="50dp" > 
   <ImageView 
    android:layout_width="45dp" 
    android:layout_height="45dp" 
    android:background="@mipmap/login_password" 
    android:id="@+id/imageView3" 
    android:layout_gravity="bottom" /> 
   <EditText 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:inputType="phone" 
    android:ems="10" 
    android:id="@+id/et_login_code" 
    android:layout_gravity="center" 
    android:layout_weight="1" 
    android:hint="      " 
    android:background="@null" 
    android:maxLength="6"/> 
   <Button 
    android:layout_width="90dp" 
    android:layout_height="30dp" 
    android:text="     " 
    android:textColor="@color/white" 
    android:id="@+id/bt_login_getcode" 
    android:background="@mipmap/login_button_blue" 
    android:layout_gravity="center_vertical" 
    android:textSize="14dp" /> 
  </LinearLayout> 
  <LinearLayout 
   android:orientation="vertical" 
   android:layout_width="match_parent" 
   android:layout_height="1dp" 
   android:background="@color/text_gray" 
   android:layout_marginBottom="10dp" /> 
  <LinearLayout 
   android:orientation="horizontal" 
   android:layout_width="match_parent" 
   android:layout_height="20dp" 
   android:id="@+id/ll_login_warning" 
   android:visibility="gone"> 
   <ImageView 
    android:layout_width="25dp" 
    android:layout_height="25dp" 
    android:background="@mipmap/login_warning" 
    android:id="@+id/imageView" 
    android:layout_gravity="center_vertical" /> 
   <TextView 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:textAppearance="?android:attr/textAppearanceMedium" 
    android:text="      " 
    android:id="@+id/tv_login_wraning" 
    android:layout_gravity="center_vertical" 
    android:textColor="@color/text_red" 
    android:textSize="13dp" /> 
  </LinearLayout> 
  <Button 
   android:layout_width="match_parent" 
   android:layout_height="40dp" 
   android:textColor="@color/white" 
   android:id="@+id/bt_login_submit" 
   android:background="@mipmap/login_button_gray" 
   android:text="   " 
   android:textSize="18dp" 
   android:layout_marginTop="10dp" /> 
 </LinearLayout> 
</LinearLayout>
메 인 코드 는 다음 과 같 습 니 다.저 는 주석 을 코드 에 추가 할 것 입 니 다.전체 모듈 의 코드 이기 때문에 다른 기능 도 있 습 니 다.

package com.millionideas.cm.login; 
import android.app.ProgressDialog; 
import android.content.Intent; 
import android.os.Bundle; 
import android.os.Handler; 
import android.text.Editable; 
import android.text.TextWatcher; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.Button; 
import android.widget.EditText; 
import android.widget.ImageView; 
import android.widget.LinearLayout; 
import android.widget.TextView; 
import com.millionideas.cm.R; 
import com.millionideas.cm.home.HomeActivity; 
import com.millionideas.cm.main.BaseActivity; 
import com.millionideas.cm.tools.TimeCountUtils; 
import org.xutils.view.annotation.ContentView; 
import org.xutils.view.annotation.Event; 
import org.xutils.view.annotation.ViewInject; 
import java.util.regex.Matcher; 
import java.util.regex.Pattern; 
@ContentView(R.layout.activity_login) 
public class LoginActivity extends BaseActivity implements View.OnLayoutChangeListener{ 
// xUtils       
 @ViewInject(R.id.iv_login_logo) 
 ImageView iv_login_logo; 
 @ViewInject(R.id.ll_login_logobg) 
 LinearLayout ll_login_logobg; 
 @ViewInject(R.id.et_login_phone) 
 EditText et_login_phone; 
 @ViewInject(R.id.et_login_code) 
 EditText et_login_code; 
 @ViewInject(R.id.ll_login_warning) 
 LinearLayout ll_login_warning; 
 @ViewInject(R.id.tv_login_wraning) 
 TextView tv_login_wraning; 
 @ViewInject(R.id.bt_login_getcode) 
 Button bt_login_getcode; 
 @ViewInject(R.id.bt_login_submit) 
 Button bt_login_submit; 
 @ViewInject(R.id.ll_login_root) 
 LinearLayout activityRootView;//        
 private TimeCountUtils timeCountUtils; 
 private Matcher phone_num; 
 private Pattern phonenumber; 
 private ProgressDialog progressDialog; 
 private Handler handler; 
 private int screenHeight = 0;//     
 private int keyHeight = 0; //           
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
  super.onCreate(savedInstanceState); 
  screenHeight = this.getWindowManager().getDefaultDisplay().getHeight(); //       
  keyHeight = screenHeight / 3;//          1/3 
  timeCountUtils = new TimeCountUtils(LoginActivity.this, 60000, 1000, bt_login_getcode);//             
  progressDialog=new ProgressDialog(this);//    
  handler=new Handler(); 
  bt_login_submit.setClickable(false); 
  et_login_phone.addTextChangedListener(new TextWatcher() {// edittext        ,                     
   @Override 
   public void beforeTextChanged(CharSequence charSequence, int i, int i1, int i2) { 
   } 
   @Override 
   public void onTextChanged(CharSequence charSequence, int i, int i1, int i2) { 
   } 
   @Override 
   public void afterTextChanged(Editable editable) { 
    if (!et_login_phone.getText().toString().equals("")){ 
     bt_login_submit.setClickable(true); 
     bt_login_submit.setBackgroundResource(R.drawable.login_button); 
    }else { 
     bt_login_submit.setClickable(false); 
     bt_login_submit.setBackgroundResource(R.mipmap.login_button_gray); 
    } 
   } 
  }); 
 } 
 //xUtils      
 @Event(value = {R.id.bt_login_submit, R.id.bt_login_getcode}, type = View.OnClickListener.class) 
 private void onClick(View view) { 
  switch (view.getId()) { 
   case R.id.bt_login_submit://       
    if (!CheckPhone(et_login_phone).matches()) {//        
     ll_login_warning.setVisibility(View.VISIBLE); 
     tv_login_wraning.setText("         "); 
    } else if (!et_login_code.getText().toString().equals("000")) {//     ,            
     ll_login_warning.setVisibility(View.VISIBLE); 
     tv_login_wraning.setText("      "); 
    } else {//      ,     
     ll_login_warning.setVisibility(View.GONE); 
     progressDialog.setMessage("    …"); 
     progressDialog.show();//        
     handler.postDelayed(new Runnable() {//    1s             
      @Override 
      public void run() {//         ,    ,     
       progressDialog.dismiss();//   hide 
       Intent intent=new Intent(LoginActivity.this, HomeActivity.class); 
       startActivity(intent); 
       LoginActivity.this.finish(); 
      } 
     },1000); 
    } 
    break; 
   case R.id.bt_login_getcode: 
    if (CheckPhone(et_login_phone).matches()) {//           ,      
     ll_login_warning.setVisibility(View.GONE); 
     bt_login_getcode.setBackgroundResource(R.mipmap.login_button_gray); 
     timeCountUtils.start(); 
    } else { 
     ll_login_warning.setVisibility(View.VISIBLE); 
     tv_login_wraning.setText("         "); 
    } 
    break; 
  } 
 } 
 public Matcher CheckPhone(EditText editText) {//        
  phonenumber = Pattern 
    .compile("^[1][3-8][0-9]{9}$"); 
  phone_num = phonenumber.matcher(editText.getText() 
    .toString()); 
  return phone_num; 
 } 
 @Override 
 protected void onResume() { 
  super.onResume(); 
  activityRootView.addOnLayoutChangeListener(this);//             
 } 
 @Override 
 public void onLayoutChange(View v, int left, int top, int right, 
        int bottom, int oldLeft, int oldTop, int oldRight, int oldBottom) { 
  /* old             ,  old               
           Activity         1/3   ,        */ 
  if (oldBottom != 0 && bottom != 0 && (oldBottom - bottom > keyHeight)) { 
   ViewGroup.LayoutParams params = iv_login_logo.getLayoutParams();//    ,       logo    
   params.height = 300; 
   params.width = 300; 
   iv_login_logo.setLayoutParams(params); 
   LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams(ll_login_logobg.getLayoutParams()); 
   lp.setMargins(0, 90, 0, 50);//    logo       
   ll_login_logobg.setLayoutParams(lp); 
  } else if (oldBottom != 0 && bottom != 0 && (bottom - oldBottom > keyHeight)) {//     ,logo      ,           
   ViewGroup.LayoutParams params = iv_login_logo.getLayoutParams(); 
   params.height = 480; 
   params.width = 480; 
   iv_login_logo.setLayoutParams(params); 
   LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams(ll_login_logobg.getLayoutParams()); 
   lp.setMargins(0, 270, 0, 150); 
   ll_login_logobg.setLayoutParams(lp); 
  } 
 } 
} 
위 에서 말 한 것 은 소 편 이 소개 한 안 드 로 이 드 로그 인 페이지 로고 가 키보드 에 따라 동적 신축(키보드 팝 업 차단 컨트롤 문 제 를 완벽 하 게 해결)을 실현 하 는 것 입 니 다.여러분 에 게 도움 이 되 기 를 바 랍 니 다.궁금 한 점 이 있 으 시 면 메 시 지 를 남 겨 주세요.소 편 은 제때에 답 해 드 리 겠 습 니 다.여기 서도 저희 사이트 에 대한 여러분 의 지지 에 감 사 드 립 니 다!

좋은 웹페이지 즐겨찾기