gpt4 book ai didi

android - 为什么 TextView.setText 会导致封闭的 ScrollView 滚动?

转载 作者:塔克拉玛干 更新时间:2023-11-03 00:33:32 31 4
gpt4 key购买 nike

我遇到了这个奇怪的问题,它发生在 1.6、2.2 和 MyTouch 3G Slide(API #7,在 Android 设备选择器中列为“2.1-Update1”)。如果有人能解释我做错了什么以及如何修复它(或者可能确认这是一个 Android 错误),我将不胜感激!

我的应用程序的基本想法是制作秒表之类的东西,因为用户可以点击一个按钮来启动计时器,然后再次点击它来停止(暂停)计时器;进一步点击在恢复计时器和暂停计时器之间交替。

我有一个顶级 ScrollView,其中包含一个 RelativeLayout,其中包含一堆小部件。第一个小部件是一个巨大的按钮(因此很容易按下),它将我所有其他小部件推到屏幕底部下方。这是有意为之的,因为我想依靠 ScrollView(以及对用户的屏幕提醒)使其余输入选项可用。

我有一个简单的状态机类型设置,其中 mState 是当前模式(用户按下任何按钮之前的 STATE_TIMER_NOT_STARTED,......第一次按下后运行,然后......第二次按下后暂停,返回到......在第三个之后运行,等等)。

除了当计时器运行时,用户再次按下开始/停止/恢复按钮,ScrollView 将向下滚动的方式外,所有这些都非常有效。我没有发出此命令(我什至没有对 ScrollView 对象的引用),我不确定它为什么这样做。

复制:编译+运行以下示例。当应用程序启动时,按“开始计时”按钮。使用拇指(或鼠标)触摸并向上拖动屏幕(这样您就可以看到 RatingBar),然后向下拖动它(这样按钮再次完全显示在屏幕上)。再次点击按钮(现在显示为“PauseTiming”),它会跳下一点。它不应该跳跃/向下滚动,因为没有声明(我可以看到)告诉它向下滚动。据我所知,导致滚动的是 setText(当我注释掉这些行时,不会发生滚动)。

我的要求是:如果我在做一些愚蠢的事情并且你可以指出它是什么,我真的很感激! :)*** 我想知道“触摸模式”是否与此有关,因为当我使用鼠标的滚轮向上移动面板(即,而不是模拟手指)时,它似乎并没有发生(在模拟器中) -拖动)。我找不到很多关于触摸模式的信息,也没有找到关于 ScrollView 中触摸模式下的焦点/选择的具体信息

如果你能确认这个错误也发生在你身上,那也没关系(因为苦难喜欢陪伴。AHEM 我的意思是,因为它可能有助于确认它不仅仅是我:) ).

MyTestApp.java

package bug.android.scrollview;

import android.app.Activity;
import android.os.Bundle;
import android.text.format.Time;
import android.view.Display;
import android.view.View;
import android.view.WindowManager;
import android.widget.Button;
import android.widget.TextView;

public class MyTestApp extends Activity {

public final static int STATE_TIMER_NOT_STARTED = 1;
public final static int STATE_TIMER_RUNNING = 2;
public final static int STATE_TIMER_PAUSED = 3;
private int mState;

Time t = new Time();

private Time data = new Time();

private Button btnStartStopResume;
private TextView lblSpacer;

@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.new_time_entry);

btnStartStopResume = (Button) findViewById(R.id.btnStartStopResume);

// Set the button's size so that the other info will also be visible
Display display = ((WindowManager) getSystemService(WINDOW_SERVICE))
.getDefaultDisplay();
// This is such a hack, but the windowScroller doesn't appear to
// have a height at this point in the lifecycle (nor in 'onResume' :( )
btnStartStopResume.setHeight(display.getHeight() - 200);

lblSpacer = (TextView) findViewById(R.id.lblSpacer);

reset();
}

public void doStartStopResume(View v) {
if (mState == MyTestApp.STATE_TIMER_NOT_STARTED) {

mState = MyTestApp.STATE_TIMER_RUNNING;

data.setToNow();

} else if (mState == MyTestApp.STATE_TIMER_RUNNING) {
mState = MyTestApp.STATE_TIMER_PAUSED;

String s = getString(R.string.add_scroll_down_to_add);
lblSpacer.setText(s);
} else if (mState == MyTestApp.STATE_TIMER_PAUSED) {

mState = MyTestApp.STATE_TIMER_RUNNING;
}
}
public void doReset(View v) {
}

public void doNewRunClick(View v) {
}

public void doAddTiming(View v) {
}

public void reset() {
mState = STATE_TIMER_NOT_STARTED;
}
}

new_time_entry.xml

<?xml version="1.0" encoding="utf-8"?>
<ScrollView
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/windowScroller"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
>
<RelativeLayout
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
>
<Button
android:id="@+id/btnStartStopResume"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="5dip"
android:text="Start Timing"
android:textSize="40dp"
android:height="290dp"
android:onClick="doStartStopResume" />

<TextView
android:id="@+id/lblSpacer"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/btnStartStopResume"
android:layout_centerHorizontal="true"
android:text="@string/add_scroll_down_for_more" />

<TextView
android:id="@+id/lblTimeStartLabel"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_below="@id/lblSpacer"
android:layout_alignParentLeft="true"
android:clickable="true"
android:onClick="adjustStartTime"
android:text="Start of this run:"
android:textSize="8dp" />

<TextView
android:id="@+id/lblTimeStart"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/lblTimeStartLabel"
android:layout_alignParentLeft="true"
android:clickable="true"
android:onClick="adjustStartTime"
android:text="--:--:-- --"
android:textColor="#FFFFFF"
android:textSize="26dp" />

<TextView
android:id="@+id/lblElapsedLabel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/lblSpacer"
android:layout_alignRight="@id/lblSpacer"
android:layout_marginRight="5dp"
android:text="Elapsed Time:"
android:textSize="8dp" />

<TextView
android:id="@+id/lblTimeElapsed"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/lblElapsedLabel"
android:layout_alignRight="@id/lblSpacer"
android:layout_marginRight="5dp"
android:textColor="#99ff66"
android:text="-- m -- sec"
android:textSize="26dp"
android:layout_marginBottom="10dip"/>

<CheckBox
android:id="@+id/chkNewRun"
android:onClick="doNewRunClick"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_below="@id/lblTimeElapsed"
android:text="This is a new run of timings"
android:layout_marginBottom="10dip" />

<TextView
android:id="@+id/lblIntensity"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="Intensity (1 = none 5 = max)"
android:layout_below="@id/chkNewRun" />

<RatingBar
android:id="@+id/rbIntensity"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/lblIntensity"
android:numStars="5"
android:rating="2"
android:layout_marginBottom="5dip" />

<TextView
android:id="@+id/lblNotes"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="Notes:"
android:layout_below="@id/rbIntensity" />

<EditText
android:id="@+id/txtNotes"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:background="@android:drawable/editbox_background"
android:layout_below="@id/lblNotes"
android:layout_marginBottom="10dip" />


<Button
android:id="@+id/btnReset"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/txtNotes"
android:layout_alignParentLeft="true"
android:layout_marginLeft="10dip"
android:layout_marginRight="10dip"
android:text="Reset"
android:onClick="doReset" />

<Button
android:id="@+id/btnOk"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/txtNotes"
android:layout_toRightOf="@id/btnReset"
android:layout_alignParentRight="true"
android:layout_marginLeft="10dip"
android:layout_marginRight="10dip"
android:text="Add Timing To List"
android:onClick="doAddTiming" />
</RelativeLayout>
</ScrollView>

字符串.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>

<string name="app_name">Timer</string>
<string name="dlg_edit_timing_title">Edit A Timing</string>
<string name="add_scroll_down_for_more">&lt; Scroll down for more options! &gt;</string>
<string name="add_scroll_down_to_add">&lt; Scroll down to save this timing! &gt;</string>
<string name="start_timing">Start Timing\n\n</string>
<string name="stop_timing">Pause Timing\n\n</string>
<string name="resume_timing">Resume Timing\n\n</string>
</resources>

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="bug.android.scrollview"
android:versionCode="1"
android:versionName="1.0">
<application android:icon="@drawable/icon" android:label="@string/app_name">
<activity android:name=".MyTestApp"
android:label="@string/app_name">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
<uses-sdk android:minSdkVersion="5" />
</manifest>

更新 1:添加

        if(  btnStartStopResume.isInTouchMode() )
Toast.makeText(this, "TOUCH MODE", 2000);
else
Toast.makeText(this, "NOT touch mode", 2000);

然后在调试器中设置断点以确认按钮始终处于触摸模式(无论我是用手指向上/向下拖动面板,还是用鼠标将其向上/向下滚动)。因此,这是在第二次按下按钮后(即,当应用程序处于“停止/暂停计时”模式时)处于触摸模式和手指拖动面板的组合,导致随后的暂停出现奇怪的额外计时。

更新 2:我只是注意到它正在向下滚动到 EditText,而没有进一步滚动。看起来当您向下移动面板时,EditText 会获得选择,并且在单击事件之后,ScrollView 会滚动回具有选择的内容。似乎解释了为什么鼠标滚轮方法没有这个问题(它将选择/焦点移回按钮)。

最佳答案

旧线程,但我想我会添加这个以防有人像我一样四处搜索。我遇到了同样的问题,但只是清除焦点并没有帮助。这就是最终为我解决的问题:

editText.clearFocus();
editText.setTextKeepState(text);

希望这对某人有帮助。 TextView docs

关于android - 为什么 TextView.setText 会导致封闭的 ScrollView 滚动?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3113465/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com