Как рисовать прямоугольники в Котлине? - PullRequest
0 голосов
/ 13 мая 2018

Я просто новичок и пытаюсь использовать canvas в Kotlin.Я пытаюсь нарисовать прямоугольники в соответствии с пользовательским вводом, который я получу от другого действия.Что я не мог сделать, так это передать массив переопределяющему классу.Вот мой код

fun drawrect(view: View){
    val layout1 = findViewById<ConstraintLayout>(R.id.layout1)
    val background = Canvass (this)
    layerheight = getIntent().getSerializableExtra("layerheight") as ArrayList<Double>;
    soilspecificweight = getIntent().getSerializableExtra("soilspecificweight") as ArrayList<Double>;
    cohesion= getIntent().getSerializableExtra("cohesion") as ArrayList<Double>;
    frictionangle = getIntent().getSerializableExtra("frictionangle") as ArrayList<Double>;
    mpeffectivestress = getIntent().getSerializableExtra("mpeffectivestress") as ArrayList<Double>;
    voidratio = getIntent().getSerializableExtra("voidratio") as ArrayList<Double>;
    compressionindex = getIntent().getSerializableExtra("compressionindex") as ArrayList<Double>;
    recompressionindex = getIntent().getSerializableExtra("recompressionindex") as ArrayList<Double>;
    bearingcapacityindex = getIntent().getSerializableExtra("bearingcapacityindex") as ArrayList<Double>;
    layout1.addView (background)

}
class Canvass (context: Context): View(context) {
    override fun onDraw (canvas: Canvas) {
        canvas.drawRGB (255, 255, 255)
        val width = width
        val footingpaint = Paint ()
        val textpaint = Paint ()
        val brush3 = Paint ()
        val brush4 = Paint ()

        footingpaint.setARGB (255, 128, 128, 128)
        textpaint.setARGB (255, 255, 255, 255)
        brush3.setARGB (255, 138, 36, 36)
        brush4.setARGB (255, 138, 36, 36)

        canvas.drawRect (((width/2)-10).toFloat(), 0f, ((width/2)+ 10) .toFloat (), 40f, footingpaint)
        canvas.drawRect (70f, 40f, (width - 70) .toFloat (), 80f, footingpaint)
        for(i in (0..layerheight.size)){

        }



    }
}

1 Ответ

0 голосов
/ 13 мая 2018
class Canvass (context: Context, layerheight: ArrayList<Double>): View(context) {

    private var layerheight: ArrayList<Double> = layerheight
    override fun onDraw (canvas: Canvas) {

        canvas.drawRGB (255, 255, 255)
        val width = width
        val footingpaint = Paint ()
        val textpaint = Paint ()
        val brush3 = Paint ()
        val brush4 = Paint ()

        footingpaint.setARGB (255, 128, 128, 128)
        textpaint.setARGB (255, 255, 255, 255)
        brush3.setARGB (255, 138, 36, 36)
        brush4.setARGB (255, 138, 36, 36)

        canvas.drawRect (((width/2)-10).toFloat(), 0f, ((width/2)+ 10) .toFloat (), 40f, footingpaint)
        canvas.drawRect (70f, 40f, (width - 70) .toFloat (), 80f, footingpaint)
        for(i in (0..layerheight.size)){
            println(layerheight)
        }

    }
}

Нашел, но если есть какое-то лучшее решение, я бы с удовольствием его проверил.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...