浅尝:iOS的CoreGraphics和Flutter的Canvas

iOS的CoreGraphic

基本就是创建一个自定义的UIView,然后重写drawRect方法,在此方法里使用UIGraphicsGetCurrentContext()来绘制目标图形和样式

objc 复制代码
#import <UIKit/UIKit.h>

@interface MyGraphicView : UIView
@end

@implementation MyGraphicView

// Only override drawRect: if you perform custom drawing.
// An empty implementation adversely affects performance during animation.
// This method is called when a view is first displayed or when an event occurs that invalidates a visible part of the view.
- (void)drawRect:(CGRect)rect {
    CGRect rectangle = CGRectMake(0, 0, 320, 100);
    CGContextRef context = UIGraphicsGetCurrentContext();
    CGContextSetRGBFillColor(context, 1.0, 1.0, 1.0, 0.0);
    CGContextSetRGBStrokeColor(context, 0.0, 1.0, 0.0, 0.5);
    CGContextFillRect(context, rectangle);
    CGContextStrokeRect(context, rectangle);
}

@end

Flutter的Canvas

这是main函数的主代码,在child节点实现一个自定义的画布

javascript 复制代码
import 'package:flutter/material.dart';

final Color darkBlue = Color.fromARGB(255, 18, 32, 47);

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      debugShowCheckedModeBanner: false,
      theme: ThemeData.dark().copyWith(scaffoldBackgroundColor: darkBlue),
      home: Scaffold(
        // Outer white container with padding 
        body: Container(
          padding: EdgeInsets.symmetric(horizontal: 40, vertical: 80),
          color: Colors.white,
          child: Container(
  				child: CustomPaint(painter: FaceOutlinePainter()),
			),
        ),
      ),
    );
  }
}

自定义一个类继承自CustomPainter,然后重写paint()方法

javascript 复制代码
class FaceOutlinePainter extends CustomPainter {
  @override
  void paint(Canvas canvas, Size size) {
    // 先定义一个画笔paint实例对象
    final paint = Paint()
      ..style = PaintingStyle.stroke
      ..strokeWidth = 4.0
      ..color = Colors.indigo;

    // 画左边的眼睛,是一个矩形的,并且有圆角20
    canvas.drawRRect(
      RRect.fromRectAndRadius(Rect.fromLTWH(20, 40, 100, 100), Radius.circular(20)),
      paint,
    );
    // 画右边的眼睛,是圆形的
    canvas.drawOval(
      Rect.fromLTWH(size.width - 120, 40, 100, 100),
      paint,
    );
    
    // 画嘴巴
    // 先初始化一个路径Path
    final mouth = Path();
    // 然后从左移动到右边
    mouth.moveTo(size.width * 0.8, size.height * 0.6);
    // 然后画椭圆曲线
    mouth.arcToPoint(
      Offset(size.width * 0.2, size.height * 0.6),
      radius: Radius.circular(150),
    );
    mouth.arcToPoint(
      Offset(size.width * 0.8, size.height * 0.6),
      radius: Radius.circular(200),
      clockwise: false,
    );

    // 把嘴巴画的线路径添加到canvas上进行绘制
    canvas.drawPath(mouth, paint);
  }

  @override
  bool shouldRepaint(FaceOutlinePainter oldDelegate) => false;
}

输出的图形大概如下所示

相关推荐
火柴就是我18 分钟前
从头写一个自己的app
android·前端·flutter
z***y8621 小时前
Swift在iOS中的Xcode
ios·xcode·swift
AirDroid_cn2 小时前
iOS 18 后台应用偷跑流量,如何限制?
macos·ios·cocoa
明君879974 小时前
Flutter 图纸标注功能的实现:踩坑与架构设计
android·ios
江东小bug王5 小时前
深入理解 UINavigationController:生命周期、动画优化与性能调优
ios
Lexiaoyao206 小时前
Apple StoreKit 2 开发指南
ios·apple
●VON7 小时前
Flutter 项目成功运行后,如何正确迁移到 OpenHarmony?常见疑问与跳转失效问题解析
flutter·华为·openharmony·开源鸿蒙
●VON7 小时前
Flutter 编译开发 OpenHarmony 全流程实战教程(基于 GitCode 社区项目)
flutter·openharmony·gitcode
消失的旧时光-194320 小时前
Flutter 组件:Row / Column
flutter
程序员老刘1 天前
Flutter版本选择指南:3.35稳定,3.38发布 | 2025年11月
flutter·客户端