Android studio 如何使自定义视图可滚动?

Android studio how to make a custom view scrollable?

我正在尝试在主线性布局中放置一个滚动视图,而在滚动视图内部是一个包含自定义视图的线性布局,我不太确定我应该怎么做才能使其正常工作。 我是android工作室的新手,如果您能指出我的错误,将不胜感激。谢谢! 我的自定义视图中的代码 class 看起来像这样

package com.example.myapplication;

import android.content.Context;
import android.content.res.Resources;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.util.AttributeSet;
import android.util.Log;
import android.view.View;

public class mview extends View {

    public int lines = 0;
    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        super.onMeasure(widthMeasureSpec, heightMeasureSpec);
    }

    public void addLine(){
        postInvalidate();
        lines++;
    }
    public mview(Context context) {
        super(context);
        init(null, 0);
    }
    public mview(Context context, AttributeSet attr) {
        super(context, attr);
        init(attr, 0);
    }
    public mview(Context context, AttributeSet attr, int def) {
        super(context, attr, def);
        init(attr, def);
    }
    private void init(AttributeSet set, int def) {
        line1.setColor(Color.BLACK);
        line1.setAntiAlias(true);
    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        //draw grids
        for (int i = 0; i < lines; i++) {
        canvas.drawLine(...);
        }
    }
}

我的主要活动中的代码 class 看起来像这样

package com.example.myapplication;
import android.widget.LinearLayout;
import android.widget.ScrollView;
import android.widget.Toast;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {
    private void clicked() {
        mview.addLine();
    }
    private mview mview;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        mview = findViewById(R.id.mview);
        setContentView(R.layout.activity_main);
        ScrollView scrollView = findViewById(R.id.scrollview);
        Button button = findViewById(R.id.button);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                clicked();
            }
        });
    }
}

我的 activity_main 布局如下所示

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">

        <ScrollView
            android:id="@+id/scrollview"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_weight="1">

            <LinearLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:orientation="vertical">

                <com.example.myapplication.mview
                    android:id="@+id/mview"
                    android:layout_width="match_parent"
                    android:layout_height="match_parent" />

            </LinearLayout>
        </ScrollView>

        <Button
            android:id="@+id/button"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:text="Button" />


    </LinearLayout>

</androidx.constraintlayout.widget.ConstraintLayout>

不用担心。只有一个小错误,如下所述,当您考虑 Layout_weight = 1 时,高度将与全屏高度匹配,因此请从代码中删除该属性:

 <ScrollView
            android:id="@+id/scrollview"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_weight="1"          // Remove this line from here
              >  

您的线性布局视图永远不会滚动,因为您已将自定义视图的高度设置为 match_parent 您必须将其更改为 wrap_content

        <com.example.myapplication.mview
            android:id="@+id/mview"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />

            <com.example.myapplication.mview
                android:id="@+id/mview"
                android:layout_width="match_parent"
                android:layout_height="wrap_content" />

并将 findViewById 移动到 setContentView 之后:

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);   //moved up
    mview = findViewById(R.id.mview);       //moved down
    ScrollView scrollView = findViewById(R.id.scrollview);
    Button button = findViewById(R.id.button);
    button.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            clicked();
        }
    });
}