2

我已经在 android 中实现了多个搜索栏,例如

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

    sb1=(SeekBar) findViewById(R.id.seekBar1);
    sb2=(SeekBar) findViewById(R.id.seekBar2);
    sb3=(SeekBar) findViewById(R.id.seekBar3);

    tv1=(TextView) findViewById(R.id.textView1);
    tv2=(TextView) findViewById(R.id.textView2);
    tv3=(TextView) findViewById(R.id.textView3);

    sb1.setOnSeekBarChangeListener(this);
    sb2.setOnSeekBarChangeListener(this);
    sb3.setOnSeekBarChangeListener(this);

}

@Override
public void onProgressChanged(SeekBar arg0, int arg1, boolean arg2) 
{

    switch (arg0.getId()) 
    {
    case R.id.seekBar1:
        tv1.setText(arg1);
        break;
    case R.id.seekBar2:
        tv2.setText(arg1);
        break;
    case R.id.seekBar3:
        tv3.setText(arg1);
        break;
    }
}

@Override
public void onStartTrackingTouch(SeekBar arg0) 
{
    // TODO Auto-generated method stub

}

@Override
public void onStopTrackingTouch(SeekBar arg0) 
{
    // TODO Auto-generated method stub

}

每当我运行此应用程序时,它都会出现以下错误:

致命例外:主要

07-18 15:41:13.200: E/AndroidRuntime(596): android.content.res.Resources$NotFoundException:String resource ID #0x1
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.content.res.Resources.getText(Resources.java:201)
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.widget.TextView.setText(TextView.java:2817)
07-18 15:41:13.200: E/AndroidRuntime(596):  at com.example.allocationseekbar.MainActivity.onProgressChanged(MainActivity.java:42)
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.widget.SeekBar.onProgressRefresh(SeekBar.java:89)
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.widget.ProgressBar.doRefreshProgress(ProgressBar.java:506)
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.widget.ProgressBar.refreshProgress(ProgressBar.java:515)
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.widget.ProgressBar.setProgress(ProgressBar.java:564)
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.widget.AbsSeekBar.trackTouchEvent(AbsSeekBar.java:337)
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.widget.AbsSeekBar.onTouchEvent(AbsSeekBar.java:292)
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.view.View.dispatchTouchEvent(View.java:3766)
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:863)
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:863)
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:863)
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:863)
07-18 15:41:13.200: E/AndroidRuntime(596):  at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:1671)
07-18 15:41:13.200: E/AndroidRuntime(596):  at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1107)
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.app.Activity.dispatchTouchEvent(Activity.java:2086)
07-18 15:41:13.200: E/AndroidRuntime(596):  at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:1655)
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.view.ViewRoot.handleMessage(ViewRoot.java:1785)
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.os.Handler.dispatchMessage(Handler.java:99)
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.os.Looper.loop(Looper.java:123)
07-18 15:41:13.200: E/AndroidRuntime(596):  at android.app.ActivityThread.main(ActivityThread.java:4627)
07-18 15:41:13.200: E/AndroidRuntime(596):  at java.lang.reflect.Method.invokeNative(Native Method)
07-18 15:41:13.200: E/AndroidRuntime(596):  at java.lang.reflect.Method.invoke(Method.java:521)
07-18 15:41:13.200: E/AndroidRuntime(596):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
07-18 15:41:13.200: E/AndroidRuntime(596):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
07-18 15:41:13.200: E/AndroidRuntime(596):  at dalvik.system.NativeStart.main(Native Method)

我不知道为什么会这样。请帮我。提前致谢

4

2 回答 2

1

您正在将一个传递给您intsetText()方法,该方法TextView是查找具有该 ID 的资源的重载。您需要将其(以及类似的行)更改为:

tv1.setText(arg1.toString()); 
于 2012-07-18T10:37:23.760 回答
0

我们可以使用以下解决方案:

 1. tv1.setText(Integer.toString(arg1))
 2. tv1.setText(""+arg1)
于 2012-07-19T11:18:09.160 回答