Skip to main content

Upload Images with text or image watermark using ASP.NET

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <table cellpadding="4" cellspacing="3">
        <tr>
            <td>
                Images:
            </td>
            <td>
                <asp:FileUpload ID="mainImg" runat="server" />
            </td>
            <td>
                &nbsp;
            </td>
        </tr>
        <tr>
            <td>
                Watermark - Text:
            </td>
            <td>
                <asp:TextBox ID="txtWater" runat="server"></asp:TextBox>
            </td>
            <td>
                &nbsp;
            </td>
        </tr>
        <tr>
            <td>
                Watermark - Images:
            </td>
            <td>
                <asp:FileUpload ID="waterImg" runat="server" />
            </td>
            <td>
                &nbsp;
            </td>
        </tr>
    </table>
    <br />
    <asp:Button ID="Button1" runat="server" Text="Uplaod Image" OnClick="Button1_Click" />
    <br />
    <asp:Image ID="Image1" runat="server" />
    </form>
</body>
</html>
/////////////////////////////////////////////////////////////////////////////////////
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.IO;
using System.Drawing.Imaging;
using System.Drawing;
using System.Drawing.Drawing2D;

public partial class test3 : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {

    }
    protected void Button1_Click(object sender, EventArgs e)
    {
        string mainImageName = "";
        string waterImageName = "";
        string waterFullPath = "";
        if (mainImg.HasFile)
        {
            //uplaod main image
            mainImageName = Path.GetFileName(mainImg.PostedFile.FileName);
            mainImg.PostedFile.SaveAs(Server.MapPath("upload/") + mainImageName);
            if (waterImg.HasFile)
            {
                //upload watermark image
                waterImageName = Path.GetFileName(waterImg.PostedFile.FileName);
                waterImg.PostedFile.SaveAs(Server.MapPath("upload/") + waterImageName);
                waterFullPath = Server.MapPath("upload/") + waterImageName;
            }
            ImageSetting(txtWater.Text, waterFullPath, Server.MapPath("upload/") + mainImageName, 450, 120);
            Image1.ImageUrl = "upload/" + mainImageName.Insert(mainImageName.LastIndexOf("."), "_new");
        }

    }
    public void ImageSetting(string wmText, string wmImage, string mainImage, int xPosition, int yPosition)
    {
        byte[] imageBytes = null;
        if (File.Exists(mainImage))
        {
            System.Drawing.Image image = System.Drawing.Image.FromFile(mainImage);
            Graphics graphic;
            if (image.PixelFormat != PixelFormat.Indexed && image.PixelFormat != PixelFormat.Format8bppIndexed && image.PixelFormat != PixelFormat.Format4bppIndexed && image.PixelFormat != PixelFormat.Format1bppIndexed)
            {
                // Graphic is not a Indexed (GIF) image
                graphic = Graphics.FromImage(image);
            }
            else
            {
                /* Cannot create a graphics object from an indexed (GIF) image.
                 * So we're going to copy the image into a new bitmap so
                 * we can work with it. */
                Bitmap indexedImage = new Bitmap(image);
                graphic = Graphics.FromImage(indexedImage);

                // Draw the contents of the original bitmap onto the new bitmap.
                graphic.DrawImage(image, 0, 0, image.Width, image.Height);
                image = indexedImage;
            }
            graphic.SmoothingMode = SmoothingMode.AntiAlias & SmoothingMode.HighQuality;

            //Text Watermark properties
            Font myFont = new Font("Arial", 25, FontStyle.Bold);
            SolidBrush brush = new SolidBrush(Color.FromArgb(70, Color.White));
            SizeF textSize = new SizeF();
            if (wmText != "")
                textSize = graphic.MeasureString(wmText, myFont);

            //Image Watermark
            System.Drawing.Image ig = null;
            if (wmImage != "")
                ig = System.Drawing.Image.FromFile(wmImage);

            // Write the text watermark and image watermark across the main image.
            PointF pointF = new PointF(xPosition, yPosition);
            if (wmText != "")
            {
                graphic.DrawString(wmText, myFont, brush, pointF);
                xPosition += Convert.ToInt32(textSize.Width);
            }
            if (wmImage != "")
            {
                graphic.DrawImage(ig, pointF);
                xPosition += Convert.ToInt32(ig.Width);
            }
            if (wmText != "")
                yPosition += Convert.ToInt32(textSize.Height);
            if (wmImage != "")
                yPosition += Convert.ToInt32(ig.Height);

            using (MemoryStream memoryStream = new MemoryStream())
            {
                // save image in memoryStream with it format which get it from GetImageFormat function
                image.Save(memoryStream, GetImageFormat(mainImage));
                imageBytes = memoryStream.ToArray();
            }
            graphic.Dispose();
        }

        MemoryStream ms = new MemoryStream(imageBytes);
        System.Drawing.Image returnImage = System.Drawing.Image.FromStream(ms);

        //save new image and rename it;
        returnImage.Save(mainImage.Insert(mainImage.LastIndexOf("."), "_new"));
        ms.Dispose();
        returnImage.Dispose();

    }

    //function to return Image Format
    ImageFormat GetImageFormat(String path)
    {
        switch (Path.GetExtension(path).ToLower())
        {
            case ".bmp": return ImageFormat.Bmp;
            case ".gif": return ImageFormat.Gif;
            case ".jpg": return ImageFormat.Jpeg;
            case ".png": return ImageFormat.Png;
            default: return null;
        }
    }
}


Now, when we upload image with any image watermark that we selected and text watermark that we type it in text watermark field, we will got as following example:

Before

Comments

Popular posts from this blog

ASP.NET MVC - Set custom IIdentity or IPrincipal

Here's how I do it. I decided to use IPrincipal instead of IIdentity because it means I don't have to implement both IIdentity and IPrincipal. Create the interface interface ICustomPrincipal : IPrincipal { int UserId { get ; set ; } string FirstName { get ; set ; } string LastName { get ; set ; } } CustomPrincipal public class CustomPrincipal : ICustomPrincipal { public IIdentity Identity { get ; private set ; } public bool IsInRole ( string role ) { return false ; } public CustomPrincipal ( string email ) { this . Identity = new GenericIdentity ( email ); } public int UserId { get ; set ; } public string FirstName { get ; set ; } public string LastName { get ; set ; } } CustomPrincipalSerializeModel - for serializing custom information into userdata field in FormsAuthenticationTicket object. public class CustomPrincipalSerializeMode...

Validate credit card number with Mod 10 algorithm in C#

Introduction All you know what information contains in your NIC number. But do you know what information contains in the Credit Card Number? Following article provides brief details about what information contain in your credit card and demonstrates to how to validate credit card number using mod 10 (Luhn) algorithms with C#. Background  Card Length   Typically, credit card numbers are all numeric and the length of the credit card number is between 12 digits to 19 digits.  14, 15, 16 digits – Diners Club 15 digits – American Express 13, 16 digits – Visa 16 digits - MasterCard   For more information please refer  http://en.wikipedia.org/wiki/Bank_card_number . Hidden information  Major Industry Identifier (MII)   The first digit of the credit card number is the Major Industry Identifier (MII). It designates the category of the entry which issued the card.     1 and 2 – Airlin...

How to Scroll to an Element with Javascript

  Overview Scrolling to a specific element or part of a webpage is mainly done to keep a user intact with the webpage for a longer period. A scroll is a function that can be used also to scroll to the beginning of a webpage from the bottom of the webpage instantly. Instant scrolling functionality is done or implemented using JavaScript. Scrolling to a particular section of a webpage adds a single-click functionality without much intervention from the user. There are different JavaScript scroll to element methods that are used to implement the functionality of scrolling to a particular element. These methods include: JavaScript  scrollIntoView  method. JavaScript  scroll  method. JavsScript  scrollTo  method. In this article, we will understand them thoroughly. Introduction Before learning about the JavaScript scroll to element, Let's learn a bit about JavaScript. JavaScript  is an object-oriented programming language used on web pages. JavaScript ...