使用canvas给图片加水印

获取本地图片

效果图

在这里插入图片描述
在这里插入图片描述

定义一个input用来选择文件,定义一个img标签用来显示选择的文件

<input
        type="file"
        accept="image/png, image/jpeg"
        id="file"
        @change="handleImgUpload"
      />
<img src="" alt="" id="originImg" />

js用来处理选择文件后如何如何显示图片

//i
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flutter中给图片水印的步骤如下: 1. 将图片载到内存中,可以使用`ImageProvider`或`File`类来载。 2. 创建一个新的画布,并将原始图片绘制到画布上。 3. 在画布上绘制水印,可以使用`TextPainter`类来绘制文字水印,或使用`ImageProvider`类来图片水印。 4. 将绘制完水印的画布保存为新的图片文件。 下面是一个简单的示例代码: ```dart import 'dart:async'; import 'dart:io'; import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; import 'package:path_provider/path_provider.dart'; import 'package:image/image.dart' as img; class WatermarkImage extends StatefulWidget { final String imagePath; final String watermarkText; WatermarkImage({required this.imagePath, required this.watermarkText}); @override _WatermarkImageState createState() => _WatermarkImageState(); } class _WatermarkImageState extends State<WatermarkImage> { late String _watermarkImagePath; @override void initState() { super.initState(); _addWatermarkToImage(); } Future<void> _addWatermarkToImage() async { final directory = await getTemporaryDirectory(); final imageFile = File(widget.imagePath); final image = img.decodeImage(imageFile.readAsBytesSync())!; final watermark = img.Image.fromBytes( 100, 50, img.encodePng(img.copyResize( img.decodeImage( (await rootBundle.load('assets/images/watermark.png')).buffer.asUint8List(), )!, width: 100, height: 50, )), ); final textPainter = TextPainter( text: TextSpan( text: widget.watermarkText, style: TextStyle( fontSize: 20, color: Colors.white, ), ), textDirection: TextDirection.ltr, )..layout(); final canvas = img.Canvas(image); canvas.drawImage(watermark, 0, 0); canvas.drawImage( img.copyResize( img.Image.fromBytes( textPainter.width.toInt(), textPainter.height.toInt(), img.encodePng( (await textPainter.toPicture().toImage(textPainter.width.toInt(), textPainter.height.toInt())) .toByteData(format: img.PixelFormat.rgba8888)! .buffer .asUint8List(), ), ), width: 100, height: 50, ), image.width - 100, image.height - 50, ); final watermarkImageFile = File('${directory.path}/watermark_${DateTime.now().millisecondsSinceEpoch}.jpg'); watermarkImageFile.writeAsBytesSync(img.encodeJpg(image)); setState(() { _watermarkImagePath = watermarkImageFile.path; }); } @override Widget build(BuildContext context) { return _watermarkImagePath != null ? Image.file( File(_watermarkImagePath), fit: BoxFit.cover, ) : Container(); } } ``` 这个示例代码将载指定路径的图片文件,并在右下角添一个水印图标和文字水印。最终生成的带有水印的新图片文件将保存在应用程序的临时目录中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值