Android自定义view七时间轴(二)---横向的图表时间轴

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_34942689/article/details/88744060

横向的时间轴图表

public class CharterXLabels extends CharterLabelsBase {
public CharterXLabels(Context context) {
    this(context, null);
}

public CharterXLabels(Context context, AttributeSet attrs) {
    this(context, attrs, 0);
}

public CharterXLabels(Context context, AttributeSet attrs, int defStyleAttr) {
    super(context, attrs, defStyleAttr);
}

@TargetApi(Build.VERSION_CODES.LOLLIPOP)
public CharterXLabels(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {
    super(context, attrs, defStyleAttr, defStyleRes);
}

@Override
public void draw(Canvas canvas) {
    super.draw(canvas);

    if (values == null || values.length == 0) {
        return;
    }

    final int valuesLength = values.length;

    final float height = getMeasuredHeight();
    final float width  = getMeasuredWidth();

    final float gap = stickyEdges ? width / (valuesLength - 1) : width / valuesLength;

    int visibilityPatternPos = -1;

    for (int i = 0; i < valuesLength; i++) {
        if (visibilityPatternPos + 1 >= visibilityPattern.length) {
            visibilityPatternPos = 0;
        } else {
            visibilityPatternPos++;
        }

        if (visibilityPattern[visibilityPatternPos]) {
            Rect textBounds = new Rect();
            paintLabel.getTextBounds(values[i]!=null?values[i]:" ", 0, values[i]!=null? values[i].length() : 1, textBounds);
            int   textHeight = 2 * textBounds.bottom - textBounds.top;
            float textWidth  = textBounds.right;

            float x;
            float y;

            switch (verticalGravity) {
                case VERTICAL_GRAVITY_TOP:
                    y = 0;
                    break;

                case VERTICAL_GRAVITY_BOTTOM:
                    y = height - textHeight;
                    break;

                default:
                    // VERTICAL_GRAVITY_CENTER
                    y = (height + textHeight) / 2;
                    break;
            }

            if (stickyEdges) {
                if (i == 0) {
                    x = 0;
                } else if (i == valuesLength - 1) {
                    x = width - textWidth;
                } else {
                    x = gap * (i - 1) + gap - (textWidth / 2);
                }
                canvas.drawText(values[i], x, y, paintLabel);
            } else {
                x = gap * i + (gap / 2) - (textWidth / 2);
                canvas.drawText(values[i], x, y, paintLabel);
            }
        }
    }
}

}

猜你喜欢

转载自blog.csdn.net/qq_34942689/article/details/88744060
今日推荐