大佬教程收集整理的这篇文章主要介绍了Android 使用Kotlin自定义View的方法教程,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
前言
随着google宣布kotlin作为官方开发语言,在Android中使用kotlin的趋势也越来越明显,最近被kotlin的文章轰炸了,所以决定上手试一下,试过之后,感觉靠它灵简直有魔性。特别是一句话写出一个复杂的循环的时候,简直被惊呆。而且使用AS,Java代码可以直接转成Kotlin。
效果图如下:
首先是这次自定义view的效果图,是一张饼图。如果是用java写的话也就几十行,觉得换成Kotlin的话可能会更少。
示例代码
主要的功能是可以任设定数据的个数,我这里是4个数据,可以任意设定每个数据的颜色。
#####首先上Kotlin代码#####
package top.greendami.mykotlinapp import android.content.Context import android.graphics.* import android.util.AttributeSet import android.view.View /** * Created by GreendaMi on 2017/4/10. */ class PPCircle : View { var mDatas = ArrayList<Float>() var mColors = ArrayList<Int>(4) var mPaint: Paint = Paint() constructor(mContext: Context) : super(mContext) { val context = mContext } constructor(mContext: Context,mAttributeSet: AttributeSet) : super(mContext,mAttributeSet) { initPaint() val context = mContext } fun initPaint() { mPaint.isAntiAlias = true mPaint.style = Paint.Style.FILL_AND_stroke mPaint.color = 0xff44b391.toInt() } //长宽一致 override fun onMeasure(widthMeasureSpec: Int,heightMeasureSpec: int) { super.onMeasure(widthMeasureSpec,heightMeasureSpeC) val widthSpecSize = View.MeasureSpec.getSize(widthMeasureSpeC) val heightSpecSize = View.MeasureSpec.getSize(heightMeasureSpeC) val mLayoutSize = Math.min(widthSpecSize,heightSpecSizE) setMeasuredDimension(mLayoutSize,mLayoutSizE) } /** * 设置数据 */ fun setData(data: ArrayList<Float>,colors: ArrayList<Int>) { mDatas = data mColors = colors invalidate() } override fun onDraw(canvas: Canvas?) { super.onDraw(canvas) if (mDatas.size == 0) { return } //切掉圆心 var mPath = Path() mPath.addCircle(width / 2f,height / 2f,width / 2f * 0.4f,Path.Direction.CW) mPath.close() canvas?.clipPath(mPath,Region.op.XOR) var @R_51_10586@l = 0f //此处亮点 mDatas.forEach { @R_51_10586@l += it } var rf = RectF(0f,0f,width.toFloat(),height.toFloat()) var startAngle = -90f//起点 var i = 0 mDatas.forEach { mPaint.color = mColors[i] var sweepAngle = it * 360 / @R_51_10586@l canvas?.drawArc(rf,startAngle,sweepAngle,true,mPaint) startAngle += sweepAngle i++ } } }
设置数据
package top.greendami.mykotlinapp import android.os.bundle import android.support.v7.app.AppCompatActivity import kotlinx.android.synthetic.main.activity_main2.* class Main2Activity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceStatE) setContentView(R.layout.activity_main2) var mDatas = ArrayList<Float>() mDatas.add(1f) mDatas.add(2f) mDatas.add(4f) mDatas.add(2f) var mColors = ArrayList<Int>() mColors.add(0xff83ccd2.toInt()) mColors.add(0xffc0e1ce.toInt()) mColors.add(0xfffac55e.toInt()) mColors.add(0xffef805f.toInt()) ppCircle.setData(mDatas,mColors) } }
<?xml version="1.0" encoding="utf-8"?> <android.support.consTraint.ConsTraintLayout xmlns:android="http://scheR_996_11845@as.android.com/apk/res/android" xmlns:app="http://scheR_996_11845@as.android.com/apk/res-auto" xmlns:tools="http://scheR_996_11845@as.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="top.greendami.mykotlinapp.Main2Activity"> <top.greendami.mykotlinapp.pPCircle android:id="@+id/ppCircle" android:layout_width="300dp" android:layout_height="300dp" app:layout_consTraintBottom_toBottomOf="parent" android:layout_marginBottom="8dp" android:layout_marginRight="8dp" app:layout_consTraintright_toRightOf="parent" app:layout_consTraintTop_toTopOf="parent" android:layout_marginTop="8dp" android:layout_marginLeft="8dp" app:layout_consTraintLeft_toLeftOf="parent" /> </android.support.consTraint.ConsTraintLayout>
package com.allrun.arsmartelevatorfoRMANager.widget; import android.content.Context; import android.graphics.Canvas; import android.graphics.Paint; import android.graphics.Path; import android.graphics.RectF; import android.graphics.Region; import android.support.Annotation.Nullable; import android.util.AttributeSet; import android.view.View; import java.util.ArrayList; import java.util.List; /** * Created by GreendaMi on 2017/4/11. */ public class PPCircle extends View { Context mContext; List<Float> mData = new ArrayList<Float>();//数据 List<Integer> mColors = new ArrayList<Integer>();//数据对应的颜色 Paint mPaint = new Paint(); public PPCircle(Context context) { super(context); } public PPCircle(Context context,@Nullable AttributeSet attrs) { super(context,attrs); mContext = context; initPaint(); } private void initPaint() { mPaint.setAntiAlias(true); mPaint.setStyle(Paint.Style.FILL_AND_stroke); } @Override protected void onMeasure(int widthMeasureSpec,int heightMeasureSpeC) { super.onMeasure(widthMeasureSpec,heightMeasureSpec); int widthSpecSize = View.MeasureSpec.getSize(widthMeasureSpec); int heightSpecSize = View.MeasureSpec.getSize(heightMeasureSpec); int mLayoutSize = Math.min(widthSpecSize,heightSpecSizE); setMeasuredDimension(mLayoutSize,mLayoutSizE); } public void setData(List<Float> mData,List<Integer> mColors) { this.mData = mData; this.mColors = mColors; } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); if (mData.size() == 0) { return; } //切掉圆心 Path mPath =new Path(); mPath.addCircle(getWidth()/2,getWidth()/2,getWidth()/2* 0.4f,Path.Direction.CW); canvas.clipPath(mPath,Region.op.XOR); float @R_51_10586@l = 0; for(float temp : mData){ @R_51_10586@l = @R_51_10586@l + temp; } RectF rf = new RectF(0f,getWidth(),getHeight()); float startAngle = -90f;//起点 int i = 0; for(float temp : mData){ mPaint.setColor(mColors.get(i)); float sweepAngle = temp * 360 / @R_51_10586@l; canvas.drawArc(rf,mPaint); startAngle += sweepAngle; i++; } } }
说说Kotlin和Java感觉差异比较大的地方。首先是变量的生命,Kotlin声明时必须赋值或者初始化,java则不用,开始有点不习惯。Kotlin不需要分号结尾,Kotlin的循环用起来简直爽YY。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对编程小技巧的@L_197_16@。
以上是大佬教程为你收集整理的Android 使用Kotlin自定义View的方法教程全部内容,希望文章能够帮你解决Android 使用Kotlin自定义View的方法教程所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。