2017-02-09 26 views
0

私はこのライブラリを使用しています:https://github.com/yshrsmz/KeyboardVisibilityEventキーボードの開閉を検出するには、android:windowSoftInputMode="adjustResize"がAndroidマニフェストに入力されている必要があります。Android AdjustResizeが正しくサイズ変更されない

このライブラリは、ソフトキーボードの開いた状態と閉じた状態を完全に検出しますが、コンテンツはadjustResizeパラメータのために表示されません。

  • のJava:

    KeyboardVisibilityEvent.setEventListener(
         AddActivity.this, 
         new KeyboardVisibilityEventListener() { 
          @Override 
          public void onVisibilityChanged(boolean isOpen) { 
           // some code depending on keyboard visiblity status 
           if (noteEditText.isFocused()) { 
            if (isOpen) { 
             Log.d("KB", "Keyboard is open"); 
             noteEditText.setLines(12); 
             noteEditText.setCursorVisible(true); 
            } else { 
             Log.d("KB", "Keyboard is closed"); 
             noteEditText.setLines(50); 
             noteEditText.setCursorVisible(false); 
            } 
           } 
          } 
         }); 
    
    noteEditText.setOnFocusChangeListener(new View.OnFocusChangeListener() { 
        @Override 
        public void onFocusChange(View v, boolean hasFocus) { 
         Log.d("KB", "onFocusChange"); 
    
         if (firstStart) { 
          noteEditText.setLines(12); 
          noteEditText.setCursorVisible(true); 
          firstStart = false; 
         } 
        } 
    }); 
    
  • XML:

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:id="@+id/add_record" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:orientation="vertical" 
    android:padding="20dp" 
    android:windowSoftInputMode="stateHidden"> 
    
    <EditText 
        android:id="@+id/title_edittext" 
        android:layout_width="match_parent" 
        android:layout_height="wrap_content" 
        android:ems="10" 
        android:hint="@string/enter_title" 
        android:inputType="textCapSentences" 
        android:textColor="@color/fontPrimary" 
        android:theme="@style/EditTextCustomCursor"> 
    
        <requestFocus /> 
    </EditText> 
    
    <EditText 
        android:id="@+id/note_edittext" 
        android:layout_width="match_parent" 
        android:layout_height="wrap_content" 
        android:background="@null" 
        android:ellipsize="end" 
        android:gravity="top|left" 
        android:hint="@string/enter_note" 
        android:inputType="textCapSentences|textMultiLine" 
        android:lines="50" 
        android:maxLines="20" 
        android:minLines="5" 
        android:paddingLeft="5dp" 
        android:scrollHorizontally="false" 
        android:scrollbars="vertical" 
        android:textColor="@color/fontPrimary" 
        android:theme="@style/EditTextCustomCursor" /> 
    

だから、これはそうそして、私は第二のEditTextのラインを調整することによって、素晴らしい作品キーボードの上に入力するが、私はcloそのEditTextの一番下までスクロールし、一番下をクリックすると、EditTextカーソルがクリックされた場所に配置されますが、最初のEditTextとSupport ActionBarが表示されずに押し下げられ、下部に大きなギャップが残ります(できるだけ下の画像(画像2)に表示されます。「F」が選択されている場所は、EditTextの一番下です。

  • 所望の効果私も試みた(正しい位置にあるすべての) Desired Effect

  • 実際の効果(サポートアクションバーと上面のEditTextがビューの外に移動されている) Actual Effect

'adjustNothing'を使用して以下を実行しますが、行の数が変更されるまでEditTextの高さが変更されず、行の変更は、キーボードが開いているか閉じているかを知っている場合にのみ変更されます。したがって

private void setupListeners() { 

    final View activityRootView = getWindow().getDecorView().findViewById(android.R.id.content); 
    activityRootView.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() { 
     @Override 
     public void onGlobalLayout() { 

      View mainView = (LinearLayout) findViewById(R.id.add_record); 
      int heightDiff = mainView.getHeight() - noteEditText.getHeight(); 
      Log.d("KB", "HeightDiff: " + heightDiff); 
      if (heightDiff > 1000 || keyboardShown) { // 99% of the time the height diff will be due to a keyboard. 
       Log.d("KB", "Keyboard is open"); 

       if (isKeyboardVisible) { 
        noteEditText.setLines(12); 
        noteEditText.setCursorVisible(true); 
        noteEditText.requestLayout(); 
        isKeyboardVisible = false; 
       } 
      } else { 
       Log.d("KB", "Keyboard is closed"); 

       if (!isKeyboardVisible) { 
        noteEditText.setLines(50); 
        noteEditText.setCursorVisible(false); 
        noteEditText.requestLayout(); 
        isKeyboardVisible = true; 
       } 
      } 
     } 
    }); 

    noteEditText.setOnClickListener(new OnClickListener() { 
     @Override 
     public void onClick(View v) { 
      numTimesClicked++; 
      Log.d("KB", "onClick: " + numTimesClicked); 

      if (clicked) { 
       // Run function 
       Log.d("KB", "clicked"); 
       InputMethodManager imm = (InputMethodManager) AddActivity.this.getSystemService(Context.INPUT_METHOD_SERVICE); 

       if (imm.isAcceptingText()) { 
        Log.d("KB", "Software Keyboard was shown"); 
        isKeyboardVisible = true; 
        keyboardShown = true; 
       } else { 
        Log.d("KB", "Software Keyboard was not shown"); 
        isKeyboardVisible = false; 
        keyboardShown = false; 
       } 
      } else { 
       Log.d("KB", "scroll"); 
       clicked = true; 
       new Handler().postDelayed(new Runnable() { 
        @Override 
        public void run() { 
         clicked = false; 
        } 
       }, 3 * 1000); 
      } 
     } 
    }); 

    noteEditText.setOnKeyListener(new View.OnKeyListener() { 
     @Override 
     public boolean onKey(View v, int keyCode, KeyEvent event) { 
      if (event.getKeyCode() == KeyEvent.KEYCODE_BACK) { 
       Log.d("KB", "closeKeyboard"); 
       noteEditText.setLines(50); 
       noteEditText.setCursorVisible(false); 
       noteEditText.requestLayout(); 
       isKeyboardVisible = false; 
      } 
      return false; 
     } 
    }); 

、私はビューのうち、他のコンテンツをプッシュのEditTextラインを(キーボードを開閉する際に)調整の所望の効果を達成していないについては行くだろうか?したがって、サポートアクションバーと最初のEditTextは常に同じ位置にとどまり、ソフトキーボードが表示されたときに2番目のEditTextだけが調整されます。

答えて

0

私は今これを解決することができました(最良の解決策ではありません)が、うまくいきます。一番上のEditTextとSupport ActionBarはビューから押し出されることはなく、2番目のEditTextは選択された行にかかわらずリサイズされます。

マニフェスト:

<activity android:theme="@style/AppTheme" 
     android:name=".activities.AddActivity" 
     android:label="@string/add_record" 
     android:windowSoftInputMode="stateVisible|adjustResize" 
     android:parentActivityName=".MainActivity" 
     android:excludeFromRecents="true"/> 
    <activity android:theme="@style/AppTheme" 
     android:name=".activities.ModifyActivity" 
     android:label="@string/modify_record" 
     android:windowSoftInputMode="stateAlwaysHidden|adjustResize" 
     android:parentActivityName=".MainActivity" 
     android:excludeFromRecents="true"/> 

ジャワ:

private void setupListeners() { 

    final LinearLayout linearLayout = (LinearLayout) findViewById(R.id.add_record); 
    if (linearLayout != null) { 
     linearLayout.setOnClickListener(new View.OnClickListener() { 
      @Override 
      public void onClick(View v) { 
       Log.d(TAG, "Clicking ll"); 
       noteEditText.requestFocus(); 

       InputMethodManager inputMethodManager = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE); 
       inputMethodManager.toggleSoftInputFromWindow(linearLayout.getApplicationWindowToken(), 
         InputMethodManager.SHOW_FORCED, 0); 
      } 
     }); 
    } 

    KeyboardVisibilityEvent.setEventListener(
      AddActivity.this, 
      new KeyboardVisibilityEventListener() { 
       @Override 
       public void onVisibilityChanged(boolean isOpen) { 
        // some code depending on keyboard visiblity status 
        Log.d(TAG, "Keyboard visibility changed"); 

        int currentLine = getCurrentCursorLine(noteEditText); 

        lineCount = noteEditText.getLineCount(); 

        if (isOpen && keyboardActuallyOpen) { 
         Log.d(TAG, "Keyboard is open"); 
         //keyboardActuallyClosed = false; 

          /* 
          scrollView.fullScroll(View.FOCUS_UP); 
          noteEditText.requestFocus(); 
          */ 

         if (currentLine < 25) { 

          getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_ADJUST_NOTHING); 

          scrollView.scrollTo(0, 0); 

          noteEditText.setMinLines(12); 
          noteEditText.setLines(12); 
          noteEditText.setMaxLines(12); 
          scrollView.scrollTo(0, 0); 

          noteEditText.setVerticalScrollBarEnabled(true); 
          scrollView.setVerticalScrollBarEnabled(false); 
          noteEditText.setCursorVisible(true); 

          scrollView.requestLayout(); 
          noteEditText.requestLayout(); 
         } else { 

          getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_ADJUST_RESIZE); 

          scrollView.scrollTo(0, 0); 
          noteEditText.setMinLines(12); 
          noteEditText.setLines(12); 
          noteEditText.setMaxLines(12); 
          scrollView.scrollTo(0, 0); 

          noteEditText.setVerticalScrollBarEnabled(true); 
          scrollView.setVerticalScrollBarEnabled(false); 
          noteEditText.setCursorVisible(true); 
         } 
        } else { 

         if (!keyboardActuallyOpen) { 


          lineCount = noteEditText.getLineCount(); 

          Log.d(TAG, "Keyboard is closed: " + lineCount); 
          noteEditText.setVerticalScrollBarEnabled(false); 
          scrollView.setVerticalScrollBarEnabled(true); 
          noteEditText.setCursorVisible(false); 

          noteEditText.setMinLines(lineCount); 
          noteEditText.setLines(lineCount); 
          noteEditText.setMaxLines(lineCount); 
          scrollView.scrollTo(0, 0); 

          keyboardActuallyOpen = false; 

          //scrollView.requestFocus(); 
          //setAdjustResize(1); 

          LinearLayout mainLayout = (LinearLayout) findViewById(R.id.add_record); 
          if (mainLayout != null) { 
           mainLayout.requestFocus(); 
          } 
         } 

        } 
       } 
      }); 

    noteEditText.setOnFocusChangeListener(new View.OnFocusChangeListener() { 
     @Override 
     public void onFocusChange(View v, boolean hasFocus) { 
      Log.d(TAG, "onFocusChange"); 

      if (firstStart) { 
       scrollView.scrollTo(0, 0); 
       noteEditText.setLines(12); 
       noteEditText.setCursorVisible(true); 
       firstStart = false; 
      } 

      if (hasFocus) { 
       Log.d(TAG, "Has Focus"); 
       keyboardActuallyOpen = true; 
      } else { 
       Log.d(TAG, "Lost focus"); 
       keyboardActuallyOpen = false; 
       setAdjustResize(2); 
      } 
     } 
    }); 
    noteEditText.setOnKeyListener(new View.OnKeyListener() { 
     @Override 
     public boolean onKey(View v, int keyCode, KeyEvent event) { 
      if (event.getKeyCode() == KeyEvent.KEYCODE_BACK) { 
       Log.d(TAG, "closeKeyboard"); 

       keyboardActuallyOpen = false; 

       noteEditText.setMinLines(lineCount); 
       noteEditText.setLines(lineCount); 
       noteEditText.setMaxLines(lineCount); 

       noteEditText.setVerticalScrollBarEnabled(false); 
       noteEditText.setCursorVisible(false); 
       noteEditText.requestLayout(); 

       scrollView.scrollTo(0, 0); 
       scrollView.setVerticalScrollBarEnabled(true); 
       scrollView.requestLayout(); 

       noteEditText.clearFocus(); 
      } 
      return false; 
     } 
    }); 


} 

のJava(押下キーボードクローズボタンのサブ分類のEditText):

public class ExtendedEditText extends EditText { 

public ExtendedEditText(Context context, AttributeSet attrs, int defStyle) { 
    super(context, attrs, defStyle); 

} 

public ExtendedEditText(Context context, AttributeSet attrs) { 
    super(context, attrs); 

} 

public ExtendedEditText(Context context) { 
    super(context); 

} 

@Override 
public boolean onKeyPreIme(int keyCode, KeyEvent event) { 
    if (event.getKeyCode() == KeyEvent.KEYCODE_BACK) { 
     dispatchKeyEvent(event); 
     return false; 
    } 
    return super.onKeyPreIme(keyCode, event); 
} 

}

XML

<?xml version="1.0" encoding="utf-8"?> 
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android" 
    android:id="@+id/add_scrollView" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" 
    android:descendantFocusability="beforeDescendants" 
    android:focusableInTouchMode="true" 
    android:fillViewport="true"> 

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
     android:id="@+id/add_record" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:orientation="vertical" 
     android:padding="20dp" 
     android:focusable="true" 
     android:focusableInTouchMode="true"> 

     <EditText 
      android:id="@+id/title_edittext" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:ems="10" 
      android:hint="@string/enter_title" 
      android:inputType="textCapSentences" 
      android:textColor="@color/fontPrimary" 
      android:theme="@style/EditTextCustomCursor"> 
     </EditText> 

     <com.securenotes.utils.ExtendedEditText 
      android:id="@+id/note_edittext" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:background="@null" 
      android:ellipsize="end" 
      android:gravity="top|left" 
      android:hint="@string/enter_note" 
      android:inputType="textCapSentences|textMultiLine" 
      android:lines="50" 
      android:maxLines="20" 
      android:minLines="5" 
      android:paddingLeft="5dp" 
      android:scrollHorizontally="false" 
      android:scrollbars="vertical" 
      android:textColor="@color/fontPrimary" 
      android:theme="@style/EditTextCustomCursor" /> 

    </LinearLayout> 
</ScrollView> 
1

わかりませんが、レイアウトの内容をScrollViewにして、ユーザーが新しい行や新しい単語を入力するたびに、scrollView.scrollTo(0,0)と設定します。代わりに、このライブラリの はまた、また、あなたがより良い習慣ですonFocusChangeListener()を使用して、これを管理することもできるhere

を参照してください、ViewTreeObserverを使用することができます。

+0

ScrollView(私の問題を部分的に解決したので)の提案をありがとうが、ユーザーがスクロールせずに行をクリックすると、最後の1つの問題がまだ発生しています。 –