Home Web Front-end uni-app Use uniapp to implement image watermark function

Use uniapp to implement image watermark function

Nov 21, 2023 pm 12:21 PM
uniapp Function Picture watermark

Use uniapp to implement image watermark function

Using uniapp to implement the image watermark function requires specific code examples

With the popularity of modern social media, image sharing has become a common way. In order to protect the copyright of images and identify the photographer, many users like to add watermarks to images. In this article, we will introduce how to use the uniapp framework to implement the image watermark function and provide detailed code examples.

uniapp is a cross-platform development framework that can be used to simultaneously develop WeChat applets, H5 pages, Android and iOS applications. To implement the image watermark function, we can draw the watermark through the canvas component in uniapp and merge it into the original image.

First, we need to create a page in the uniapp project to display the image watermark effect. In the layout of the page, we can use the canvas component provided by uniapp to draw pictures and watermarks. The following is a simple example:

<template>
  <view class="container">
    <canvas class="canvas" id="myCanvas" @canvasId="onCanvasId"></canvas>
  </view>
</template>

<script>
export default {
  data() {
    return {
      canvasId: "",
      imageUrl: "",
      watermarkText: "Watermark",
    };
  },
  methods: {
    // 获取canvas的id
    onCanvasId(e) {
      this.canvasId = e.mp.detail.canvasId;
      this.drawImage();
    },
    // 绘制图片和水印
    drawImage() {
      const ctx = uni.createCanvasContext(this.canvasId, this);
      const canvasWidth = 300;
      const canvasHeight = 300;

      // 绘制图片
      ctx.drawImage(this.imageUrl, 0, 0, canvasWidth, canvasHeight);

      // 绘制水印
      ctx.setFontSize(16);
      ctx.setFillStyle("rgba(255, 255, 255, 0.5)");
      ctx.setTextBaseline("middle");
      ctx.setTextAlign("center");
      ctx.fillText(
        this.watermarkText,
        canvasWidth / 2,
        canvasHeight / 2
      );

      ctx.draw(false, () => {
        // 将canvas转换为图片
        uni.canvasToTempFilePath(
          {
            canvasId: this.canvasId,
            success: (res) => {
              // 保存水印图片
              this.saveImage(res.tempFilePath);
            },
            fail: () => {
              console.log("canvasToTempFilePath failed");
            },
          },
          this
        );
      });
    },
    // 保存图片
    saveImage(path) {
      uni.saveImageToPhotosAlbum({
        filePath: path,
        success: () => {
          uni.showToast({
            title: "图片保存成功",
            icon: "success",
            duration: 2000,
          });
        },
        fail: () => {
          uni.showToast({
            title: "图片保存失败",
            icon: "none",
            duration: 2000,
          });
        },
      });
    },
  },
  mounted() {
    // 设置原始图片路径
    this.imageUrl = "xxx";
  },
};
</script>
Copy after login

In the above code, we obtain the id of the canvas component through the onCanvasId method, and then call the drawImage method to draw pictures and watermarks on the canvas. To draw an image, you need to use the ctx.drawImage method, and to draw a watermark, you need to use the ctx.fillText method. Finally, we can convert the canvas to a temporary file path through the uni.canvasToTempFilePath method, and then use the uni.saveImageToPhotosAlbum method to save the watermark image to the album.

It should be noted that in actual development, we can pass the path and text content of images and watermarks as parameters into the component to achieve more flexible functions.

Summary:

This article introduces how to use uniapp to implement the image watermark function, and provides detailed code examples. By using the canvas component, we can draw a watermark on the image and save it as a new image. I hope this article will be helpful to developers who need to implement the image watermark function. If you have any questions, please leave a message for discussion.

The above is the detailed content of Use uniapp to implement image watermark function. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

The difference between vivox100s and x100: performance comparison and function analysis The difference between vivox100s and x100: performance comparison and function analysis Mar 23, 2024 pm 10:27 PM

Both vivox100s and x100 mobile phones are representative models in vivo's mobile phone product line. They respectively represent vivo's high-end technology level in different time periods. Therefore, the two mobile phones have certain differences in design, performance and functions. This article will conduct a detailed comparison between these two mobile phones in terms of performance comparison and function analysis to help consumers better choose the mobile phone that suits them. First, let’s look at the performance comparison between vivox100s and x100. vivox100s is equipped with the latest

What exactly is self-media? What are its main features and functions? What exactly is self-media? What are its main features and functions? Mar 21, 2024 pm 08:21 PM

With the rapid development of the Internet, the concept of self-media has become deeply rooted in people's hearts. So, what exactly is self-media? What are its main features and functions? Next, we will explore these issues one by one. 1. What exactly is self-media? We-media, as the name suggests, means you are the media. It refers to an information carrier through which individuals or teams can independently create, edit, publish and disseminate content through the Internet platform. Different from traditional media, such as newspapers, television, radio, etc., self-media is more interactive and personalized, allowing everyone to become a producer and disseminator of information. 2. What are the main features and functions of self-media? 1. Low threshold: The rise of self-media has lowered the threshold for entering the media industry. Cumbersome equipment and professional teams are no longer needed.

How to start preview of uniapp project developed by webstorm How to start preview of uniapp project developed by webstorm Apr 08, 2024 pm 06:42 PM

Steps to launch UniApp project preview in WebStorm: Install UniApp Development Tools plugin Connect to device settings WebSocket launch preview

Which one is better, uniapp or mui? Which one is better, uniapp or mui? Apr 06, 2024 am 05:18 AM

Generally speaking, uni-app is better when complex native functions are needed; MUI is better when simple or highly customized interfaces are needed. In addition, uni-app has: 1. Vue.js/JavaScript support; 2. Rich native components/API; 3. Good ecosystem. The disadvantages are: 1. Performance issues; 2. Difficulty in customizing the interface. MUI has: 1. Material Design support; 2. High flexibility; 3. Extensive component/theme library. The disadvantages are: 1. CSS dependency; 2. Does not provide native components; 3. Small ecosystem.

What are the functions of Xiaohongshu account management software? How to operate a Xiaohongshu account? What are the functions of Xiaohongshu account management software? How to operate a Xiaohongshu account? Mar 21, 2024 pm 04:16 PM

As Xiaohongshu becomes popular among young people, more and more people are beginning to use this platform to share various aspects of their experiences and life insights. How to effectively manage multiple Xiaohongshu accounts has become a key issue. In this article, we will discuss some of the features of Xiaohongshu account management software and explore how to better manage your Xiaohongshu account. As social media grows, many people find themselves needing to manage multiple social accounts. This is also a challenge for Xiaohongshu users. Some Xiaohongshu account management software can help users manage multiple accounts more easily, including automatic content publishing, scheduled publishing, data analysis and other functions. Through these tools, users can manage their accounts more efficiently and increase their account exposure and attention. In addition, Xiaohongshu account management software has

What development tools do uniapp use? What development tools do uniapp use? Apr 06, 2024 am 04:27 AM

UniApp uses HBuilder

PHP Tips: Quickly Implement Return to Previous Page Function PHP Tips: Quickly Implement Return to Previous Page Function Mar 09, 2024 am 08:21 AM

PHP Tips: Quickly implement the function of returning to the previous page. In web development, we often encounter the need to implement the function of returning to the previous page. Such operations can improve the user experience and make it easier for users to navigate between web pages. In PHP, we can achieve this function through some simple code. This article will introduce how to quickly implement the function of returning to the previous page and provide specific PHP code examples. In PHP, we can use $_SERVER['HTTP_REFERER'] to get the URL of the previous page

What basics are needed to learn uniapp? What basics are needed to learn uniapp? Apr 06, 2024 am 04:45 AM

uniapp development requires the following foundations: front-end technology (HTML, CSS, JavaScript) mobile development knowledge (iOS and Android platforms) Node.js other foundations (version control tools, IDE, mobile development simulator or real machine debugging experience)

See all articles