Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/230.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android 编辑约束布局中的文本滚动条问题_Android_Android Edittext_Android Constraintlayout - Fatal编程技术网

Android 编辑约束布局中的文本滚动条问题

Android 编辑约束布局中的文本滚动条问题,android,android-edittext,android-constraintlayout,Android,Android Edittext,Android Constraintlayout,只有当编辑文本的高度达到布局高度的末尾时,我才尝试在编辑文本中显示滚动条。如果我正在输入/添加空白,这可以正常工作,但当我的文本达到编辑文本宽度的末尾时,这会导致问题。一旦我的文本到达编辑文本宽度的末端,它就会开始显示滚动条,而当我到达屏幕的(高度)末端时,它就会显示出来 请告知我如何解决此问题。请查看附件中的图片和代码以供参考 这可能有助于我编辑代码中的一些内容。我已经移除了障碍物,并用一条水平线对其进行了更改,并将该线设置为屏幕高度的80%,并且页脚对象与该水平线对齐。请看下面的代码,我希望

只有当编辑文本的高度达到布局高度的末尾时,我才尝试在编辑文本中显示滚动条。如果我正在输入/添加空白,这可以正常工作,但当我的文本达到编辑文本宽度的末尾时,这会导致问题。一旦我的文本到达编辑文本宽度的末端,它就会开始显示滚动条,而当我到达屏幕的(高度)末端时,它就会显示出来

请告知我如何解决此问题。请查看附件中的图片和代码以供参考


这可能有助于我编辑代码中的一些内容。我已经移除了障碍物,并用一条水平线对其进行了更改,并将该线设置为屏幕高度的80%,并且页脚对象与该水平线对齐。请看下面的代码,我希望它能解决您的问题。如果您对我如何设置约束有任何疑问,我很乐意提供帮助

   <?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <EditText
        android:id="@+id/editFeedback"
        android:layout_width="0dp"
        android:layout_height="0dp"
        android:layout_marginBottom="60dp"
        android:bufferType="spannable"
        android:gravity="top"
        android:hint="Some text"
        android:inputType="textCapSentences|textMultiLine"
        android:minHeight="120dp"
        android:overScrollMode="ifContentScrolls"
        android:scrollbarStyle="insideInset"
        android:scrollbars="vertical"
        android:selectAllOnFocus="true"
        android:textIsSelectable="true"
        android:textSize="16sp"
        app:layout_constraintBottom_toTopOf="@+id/guideline"
        app:layout_constraintEnd_toEndOf="@id/guidelineEnd"
        app:layout_constraintHeight_default="wrap"
        app:layout_constraintStart_toStartOf="@id/guidelineStart"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_chainStyle="packed"
        tools:text="" />

    <Button
        android:id="@+id/buttonSend"
        style="@style/Widget.AppCompat.Button.Colored"
        android:layout_width="wrap_content"
        android:layout_height="50dp"
        android:layout_gravity="end"
        android:layout_marginBottom="8dp"
        android:layout_marginTop="8dp"
        android:text="Send"
        android:textAllCaps="false"
        app:layout_constraintBottom_toTopOf="@+id/guideline"
        app:layout_constraintEnd_toEndOf="@id/guidelineEnd"
        app:layout_constraintTop_toBottomOf="@+id/editFeedback"
        app:layout_constraintVertical_bias="0.00999999" />

    <TextView
        android:id="@+id/Footer"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="start"
        android:layout_marginBottom="8dp"
        android:text="This is a footer"
        android:textSize="15sp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="@+id/guideline" />

    <android.support.constraint.Guideline
        android:id="@+id/guidelineStart"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_constraintGuide_begin="8dp" />

    <android.support.constraint.Guideline
        android:id="@+id/guidelineEnd"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_constraintGuide_end="8dp" />

    <android.support.constraint.Guideline
        android:id="@+id/guideline"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        app:layout_constraintGuide_percent="0.8" />

</android.support.constraint.ConstraintLayout>


它的工作在我这边请在你这边检查可能是它的

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <EditText
        android:id="@+id/editFeedback"
        android:layout_width="0dp"
        android:layout_height="0dp"
        android:bufferType="spannable"
        android:gravity="top"
        android:hint="Some text"
        android:inputType="textCapSentences|textMultiLine"
        android:minHeight="120dp"
        android:overScrollMode="ifContentScrolls"
        android:scrollbarStyle="insideInset"
        android:scrollbars="vertical"
        android:selectAllOnFocus="true"
        android:textIsSelectable="true"
        android:textSize="16sp"
        app:layout_constraintBottom_toTopOf="@+id/buttonSend"
        app:layout_constraintEnd_toEndOf="@+id/guidelineEnd"
        app:layout_constraintHeight_default="wrap"
        app:layout_constraintStart_toStartOf="@+id/guidelineStart"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.0"
        app:layout_constraintVertical_chainStyle="packed"
        tools:text="" />

    <Button
        android:id="@+id/buttonSend"
        style="@style/Widget.AppCompat.Button.Colored"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="end"
        android:text="Send"
        android:textAllCaps="false"
        app:layout_constraintBottom_toBottomOf="@+id/barrierEnd"
        app:layout_constraintEnd_toEndOf="@+id/guidelineEnd"
        app:layout_constraintTop_toBottomOf="@+id/editFeedback" />

    <TextView
        android:id="@+id/Footer"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="start"
        android:layout_marginBottom="100dp"
        android:text="This is a footer"
        android:textSize="15sp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent" />

    <android.support.constraint.Guideline
        android:id="@+id/guidelineStart"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_constraintGuide_begin="8dp" />

    <android.support.constraint.Guideline
        android:id="@+id/guidelineEnd"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_constraintGuide_end="8dp" />

    <android.support.constraint.Barrier
        android:id="@+id/barrierEnd"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        app:barrierDirection="top"
        app:constraint_referenced_ids="Footer" />

</android.support.constraint.ConstraintLayout>

我相信它可以通过编程实现

当文本到达行的最后一个字符时,禁用垂直滚动条就可以了<代码>编辑文本。setVerticalScrollBarEnabled(false)。此外,文本返回下一行后,滚动条可以再次设置为true
editText.setVerticalScrollBarEnabled(true)

我的良好开端可能是实现
TextWatcher
EditText.OnScrollChangeListener
等接口,并在启用/禁用滚动条时同时使用这两个接口

这里的问题是。如果未在清单中指定
windowSoftInputMode
,则默认为
stateunotified
adjustunnotified

现在,当软键盘打开时,
EditText
正在调整大小。尝试添加一个
windowSoftInputMode
,以避免调整版面大小或将版面置于
滚动视图中(如果您希望在软键盘打开期间整个版面可见)

您可以指定
adjustNothing
标志。这将阻止重新调整大小

<activity android:name=".MainActivity"
        android:windowSoftInputMode="adjustNothing"
        >
    </activity>


请说明您使用的ConstraintLayout的版本。据我所知,使用标准EditText无法做到这一点。你说你想要垂直条,但只有当编辑文本达到“X”大小时,你才需要测量你的编辑文本,只有当你达到某个阈值时,你才能通过编程启用滚动条。当你说“当文本达到EditText的宽度时,它显示滚动条”您假设这不是EditText的第一行,而是最后一行,对吗?意思EditText“文本在最后一行的高度吗?@Martin Marconcini我们在项目中使用的是约束布局版本1.1.0。可以共享您的代码。@RedM是的,我知道,但我需要编辑文本在到达底部时显示滚动条,它可以显示滚动条,奇怪的是我无法从EditText中选择任何文本。当我尝试时因此,只有当编辑文本的高度刚好高于页脚时,才会显示滚动条。你也可以展示一幅详细的问题图片,比如,用你实际上喜欢的那种方式展示的文本。这将是非常有帮助的是,它将完美地工作时,你点击输入为新行,但在正常的键入,而不点击输入后,它将显示最小编辑文本高度后的滚动条reached@Jinu这就是EditText的本质,如果您需要自定义行为,您必须尽可能多地编写自己的/extend/delegate。@MartinMarconcini它在其他布局上工作得非常好,因此我为此提出了一个bug
<activity android:name=".MainActivity"
        android:windowSoftInputMode="adjustNothing"
        >
    </activity>