自定义搜索栏与TextViews

时间:2015-07-09 07:28:54

标签: android textview seekbar

我希望制作一个相当复杂的CustomSeekBar。我找到的教程并没有帮助我,这对我来说是个新的基础。

我的目标是看起来像这样:https://morgazmo99-yahoo-com.tinytake.com/sf/MjIwMjM2XzEzNzI5MzQ

我需要将所有获取,设置,监听和更新代码都包含在我的CustomSeekBar类中。 textViewA和textViewB应该由重写的onProgressChanged方法自动更新,尽管每个方法还需要一个OnClickListener来向这些视图添加额外的数据。

我想我会接近,但我不知道如何将视图封装到我的CustomSeekBar类中。我在尝试设置TextView时得到NPE,我基本上理解为什么,但我确定我希望CustomSeekBar组件管理这些TextView。

我真的只是想在如何从我的自定义类中的OnProgressChanged正确更新TextViews方面寻求帮助。代码如下:

到目前为止,我的XML看起来很合适..

<RelativeLayout

            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"
            tools:context=".MainActivity" >

<TextView

    android:id="@+id/textViewTitle"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Center of Gravity"
    android:layout_alignParentStart="true"
    android:layout_alignParentLeft="true"
    android:layout_marginStart="@dimen/seekbar_margin"
    android:layout_marginLeft="@dimen/seekbar_margin"
    android:layout_marginTop="14dp" />

<com.sample.myapp.CustomSeekBar

    android:id="@+id/customseekBar"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:layout_below="@+id/textViewTitle"
    android:progressDrawable="@android:color/transparent"
    android:max="100"
    android:progress="50"/>

<TextView

    android:id="@+id/textViewA"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="A"
    android:layout_alignParentStart="true"
    android:layout_alignParentLeft="true"
    android:layout_below="@+id/customseekBar"
    android:layout_marginStart="@dimen/seekbar_margin"
    android:layout_marginLeft="@dimen/seekbar_margin"
    android:layout_marginTop="@dimen/seekbar_text_padding"
    android:clickable="true"/>

<TextView

    android:id="@+id/textViewB"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="B"
    android:layout_alignParentEnd="true"
    android:layout_alignParentRight="true"
    android:layout_below="@+id/customseekBar"
    android:layout_marginEnd="@dimen/seekbar_margin"
    android:layout_marginRight="@dimen/seekbar_margin"
    android:layout_marginTop="@dimen/seekbar_text_padding"
    android:clickable="true"/>

</RelativeLayout>

我确实有一个CustomSeekBar类到达那里:

package com.sample.myapp;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Rect;
import android.util.AttributeSet;
import android.widget.SeekBar;

public class CustomSeekBar extends SeekBar implements SeekBar.OnSeekBarChangeListener {

private Rect rect;
private Paint paint;
private int seekbar_height, textViewAPercentage, textViewBPercentage;
private String textViewTitleText, textViewAText, textViewBText;;

private TextView textViewA, textViewB, textViewTitle;

public CustomSeekBar(Context context) {

    super(context);
    setOnSeekBarChangeListener(this);

}

public CustomSeekBar(Context context, AttributeSet attrs) {

    super(context, attrs);
    setOnSeekBarChangeListener(this);
    rect = new Rect();
    paint = new Paint();
    seekbar_height = 6;

}

public CustomSeekBar(Context context, AttributeSet attrs, int defStyle) {

    super(context, attrs, defStyle);
    setOnSeekBarChangeListener(this);

}

public void setTextViewTitleText(String string) {
    this.textViewTitleText = string;
}

public String getTextA() {
    return textViewAText;
}

public void setTextA(String string) {
    this.textViewAText = string;
}

public String getTextB() {
    return textViewBText;
}

public void setTextB(String string) {
    this.textViewBText = string;
}

@Override
public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) {

    int seekBarMax = seekBar.getMax();
    textViewAPercentage = (seekBarMax / progress) * 100;
    textViewBPercentage = ((seekBarMax - progress) / seekBarMax) * 100;

    String A, B;

    if (textViewAText != null) A = String.valueOf(textViewAPercentage) + "\n" + textViewAText;
    else A = String.valueOf(textViewAPercentage);

    if (textViewBText != null) B = String.valueOf(textViewBPercentage) + "\n" + textViewBText;
    else B = String.valueOf(textViewBPercentage);

    textViewA = (TextView) findViewById(R.id.textViewA);
    textViewB = (TextView) findViewById(R.id.textViewB);

    textViewA.setText(A);
    textViewB.setText(B);

}

@Override
public void onStartTrackingTouch(SeekBar seekBar) {

}

@Override
public void onStopTrackingTouch(SeekBar seekBar) {

}

@Override
protected synchronized void onDraw(Canvas canvas) {

    rect.set(0 + getThumbOffset(), (getHeight() / 2) - (seekbar_height / 2), getWidth() - getThumbOffset(), (getHeight() / 2) + (seekbar_height / 2));
    paint.setColor(Color.GRAY);
    canvas.drawRect(rect, paint);
    if (this.getProgress() > 50) {

        rect.set(getWidth() / 2,  (getHeight() / 2) - (seekbar_height / 2), getWidth() / 2 + (getWidth() / 100) * (getProgress() - 50), getHeight() / 2 + seekbar_height / 2));

        paint.setColor(Color.CYAN);
        canvas.drawRect(rect, paint);

    }

    if (this.getProgress() < 50) {

        rect.set(getWidth() / 2 - ((getWidth() / 100) * (50 - getProgress())), (getHeight() / 2) - (seekbar_height / 2), getWidth() / 2, getHeight() / 2 + (seekbar_height / 2));

        paint.setColor(Color.CYAN);
        canvas.drawRect(rect, paint);

    }

    super.onDraw(canvas);

}

}

1 个答案:

答案 0 :(得分:1)

使用以下代码

interface iSeekChangeListener {
   public void onChange(String a, String b);
}

将iSeekChangeListener实现到您的活动类并覆盖onChange(),如下所示

 @Override
    public void onChange(String a, String b) {

        textViewA.setText(a);
        textViewB.setText(b);
    }
你的CustomSeekBar类中的

设置了监听器

  public void setListener(iSeekChangeListener customSeekActivty) {

        this.customSeekListener = customSeekActivty;
    }

在你的Activity中你需要设置监听器

customSeekBar.setListener(this);

在CustomSeekBar的onProgressChange()中

if (customSeekListener != null)
            customSeekListener.onChange(A, B);