自定义View,绘制图文混合

本文介绍了一个使用Android自定义View进行图形绘制的例子,包括圆形、弧形和文本的绘制过程。通过设置画笔样式、颜色及宽度等属性,演示了如何在自定义View中实现复杂的图形绘制。
package com.example.user.demopine;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Rect;
import android.graphics.RectF;
import android.support.annotation.Nullable;
import android.util.AttributeSet;

/**
 * @author ${pym}
 * @creatDate 2017/9/6 15:47
 * @description ${description}
 * @updateAuthor ${Author}
 * @updateDate$ 2017/9/6 15:47
 */

public class View extends android.view.View {
    private int w;
    private int h;

    public View(Context context) {
        super(context);
    }

    public View(Context context, @Nullable AttributeSet attrs) {
        super(context, attrs);
    }

    public View(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }

    public View(Context context, @Nullable AttributeSet attrs, int defStyleAttr, int defStyleRes) {
        super(context, attrs, defStyleAttr, defStyleRes);
    }

    public View(Context context, int w, int h) {
        super(context);
        this.w = w;
        this.h = h;
    }

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

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        String text = "测试";
        Paint pain = new Paint();
        pain.setAntiAlias(true);
        pain.setColor(Color.RED);
        pain.setStyle(Paint.Style.STROKE);
        pain.setStrokeWidth(2);
        float radius = Math.min(w, h) / 2;
        Rect rect = new Rect(w, h, h, h);
        canvas.drawCircle(rect.centerX(), rect.centerY(), radius, pain);

        RectF rectF = new RectF(w/2, h/2, w+(w/2), h+(h/2));
        pain.setColor(Color.RED);
        pain.setStyle(Paint.Style.FILL_AND_STROKE);
        canvas.drawArc(rectF, 0, 180, false, pain);

        pain.setStyle(Paint.Style.FILL_AND_STROKE);
        pain.setTextSize(28);
        pain.setStrokeWidth(0);
        canvas.drawText(text, rect.centerX() - 20, rect.centerY() - 20, pain);
        pain.setColor(Color.WHITE);
        pain.setStrokeWidth(5);
        canvas.drawLine(rect.centerX(), rect.centerY() + 25, rect.centerX(), rect.centerX() + 75, pain);
        canvas.drawLine(rect.centerX() - 25, rect.centerX() + 50, rect.centerX() + 25, rect.centerY() + 50, pain);
    }

}


package com.example.user.demopine;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.widget.LinearLayout;


public class MainActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        LinearLayout ll1 = (LinearLayout) findViewById(R.id.ll);
        LinearLayout ll2 = (LinearLayout) findViewById(R.id.ll2);
        View view2 = new View(this, 800, 800);
        ll2.addView(view2);

    }
}
 
内容概要:本文详细介绍了一种基于Simulink的表贴式永磁同步电机(SPMSM)有限控制集模型预测电流控制(FCS-MPCC)仿真系统。通过构建PMSM数学模型、坐标变换、MPC控制器、SVPWM调制等模块,实现了对电机定子电流的高精度跟踪控制,具备快速动态响应和低稳态误差的特点。文中提供了完整的仿真建模步骤、关键参数设置、核心MATLAB函数代码及仿真结果分析,涵盖转速、电流、转矩和三相电流波形,验证了MPC控制策略在动态性能、稳态精度和抗负载扰动方面的优越性,并提出了参数自整定、加权代价函数、模型预测转矩控制和弱磁扩速等优化方向。; 适合人群:自动化、电气工程及其相关专业本科生、研究生,以及从事电机控制算法研究与仿真的工程技术人员;具备一定的电机原理、自动控制理论和Simulink仿真基础者更佳; 使用场景及目标:①用于永磁同步电机模型预测控制的教学演示、课程设计或毕业设计项目;②作为电机先进控制算法(如MPC、MPTC)的仿真验证平台;③支撑科研中对控制性能优化(如动态响应、抗干扰能力)的研究需求; 阅读建议:建议读者结合Simulink环境动手搭建模型,深入理解各模块间的信号流向与控制逻辑,重点掌握预测模型构建、代价函数设计与开关状态选择机制,并可通过修改电机参数或控制策略进行拓展实验,以增强实践与创新能力。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

GodCodeApps

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值