如何相对于另一个视图的位置进行绘制



我正在尝试在TextView下画一条线(创建一个橡皮桥得分表,其中有问题的线反映了这里的虚线(。我不知道如何获取最底部 TextView 的位置并使用这些数字在正确的位置创建一行。该行目前远低于文本视图,它应该紧挨着它,即:

40
——— <---- 我想要这个(接近数字(

40

——— <----我得到这个(离数字更远(

该行确实会根据最底部 TextView 的垂直位置更改位置,所以我认为我成功地检索了它的位置,但不知何故我没有正确使用它来绘制线条。

下面是获取 TextView 的位置并将其发送到线条绘制方法的代码:

    findViewById(R.id.main).getViewTreeObserver().addOnGlobalLayoutListener(
            new ViewTreeObserver.OnGlobalLayoutListener() {
                @Override
                public void onGlobalLayout() {
                    //remove listener
                    if( Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN )
                        findViewById(R.id.main).getViewTreeObserver()
                                .removeOnGlobalLayoutListener(this);
                    else
                        findViewById(R.id.main).getViewTreeObserver()
                                .removeGlobalOnLayoutListener(this);
                    TextView bottomTextView = (TextView) weGameLayout
                            .getChildAt(weGameLayout.getChildCount() - 1);
                    int[] pos = new int [2];
                    bottomTextView.getLocationOnScreen(pos);
                    int gameLinePosition = pos[1];
                    int height = bottomTextView.getHeight();
                    ((BackgroundLines)findViewById(R.id.background_lines))
                            .addGameLine(gameLinePosition + height - topdiff);
                }
            }
    );

这是画线的方法:

public void addGameLine(int position) {
    ShapeDrawable line = new ShapeDrawable(new RectShape());
    gameLines.add(line);
    gameLinePositions.add(position);
    invalidate();
}
@Override
public void onDraw(Canvas canvas) {
    int width = this.getWidth();
    for( int i=0; i < gameLines.size(); ++i ){
        ShapeDrawable gameLine = gameLines.get(i);
        int position = gameLinePositions.get(i);
        gameLine.setBounds(0, position-2, width, position+2);
        gameLine.draw(canvas);
    }
}

如果更多信息有用,请告诉我!这似乎是一个微妙的问题,有点难以描述,但我认为我对 android 布局或图纸管理的无知主要是错的。

编辑 这是主要布局。它很长,但我认为几乎所有相关的东西都在顶部

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">
    <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        android:elevation="4dp"
        android:theme="@style/ThemeOverlay.AppCompat.ActionBar" />
    <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:id="@+id/main"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:paddingBottom="@dimen/activity_vertical_margin"
        android:paddingLeft="@dimen/activity_horizontal_margin"
        android:paddingRight="@dimen/activity_horizontal_margin"
        android:paddingTop="@dimen/activity_vertical_margin"
        android:background="@drawable/parchment_scroll_background"
        tools:context="com.pianomansb.betterbridgescoresheet.MainActivity">
        <com.pianomansb.betterbridgescoresheet.BackgroundLines
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:id="@+id/background_lines" />
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="horizontal">
            <LinearLayout
                android:id="@+id/we_column"
                android:layout_width="0dp"
                android:layout_weight="1"
                android:layout_height="match_parent"
                android:orientation="vertical">
                <LinearLayout
                    android:id="@+id/we_upper"
                    android:layout_width="match_parent"
                    android:layout_height="0dp"
                    android:layout_weight="1"
                    android:orientation="vertical">
                    <TextView
                        android:id="@+id/we_text"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_gravity="center_horizontal"
                        android:text="@string/we_text"
                        style="@style/WeTheyFont"/>
                    <LinearLayout
                        android:id="@+id/we_bonus"
                        android:layout_width="match_parent"
                        android:layout_height="match_parent"
                        android:orientation="vertical"
                        android:gravity="bottom">
                    </LinearLayout>
                </LinearLayout>
                <LinearLayout
                    android:id="@+id/we_game"
                    android:layout_width="match_parent"
                    android:layout_height="0dp"
                    android:layout_weight="1"
                    android:orientation="vertical">
                </LinearLayout>
            </LinearLayout>
            <LinearLayout
                android:id="@+id/they_column"
                android:layout_width="0dp"
                android:layout_weight="1"
                android:layout_height="match_parent"
                android:orientation="vertical">
                <LinearLayout
                    android:id="@+id/they_upper"
                    android:layout_width="match_parent"
                    android:layout_height="0dp"
                    android:layout_weight="1"
                    android:orientation="vertical">
                    <TextView
                        android:id="@+id/they_text"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_gravity="center_horizontal"
                        android:text="@string/they_text"
                        style="@style/WeTheyFont"/>
                    <LinearLayout
                        android:id="@+id/they_bonus"
                        android:layout_width="match_parent"
                        android:layout_height="match_parent"
                        android:orientation="vertical"
                        android:gravity="bottom">
                    </LinearLayout>
                </LinearLayout>
                <LinearLayout
                    android:id="@+id/they_game"
                    android:layout_width="match_parent"
                    android:layout_height="0dp"
                    android:layout_weight="1"
                    android:orientation="vertical">
                </LinearLayout>
            </LinearLayout>
        </LinearLayout>
    </FrameLayout>
</LinearLayout>

听起来您正在尝试比通常的视图布局工具更复杂的事情。 我不会告诉你停止那样尝试,但我会推荐一种完全不同的方法,对你来说可能更容易。

我会使整个事情成为自定义视图(除非它可以非常高,否则它可能是完全不同的问题。确保您的 View 子类正确宣传其首选高度和宽度。

在 onDraw 中,像往常一样在画布上画线条。 请注意,您也可以在画布上绘制文本,而无需文本视图。 只需使用 Canvas.drawText(( 按所需方式定位文本,并使用该方法的 Paint 参数对文本进行大小和着色。

我希望这对你来说是一个更好的策略。

最新更新