로고가 포함된 QR 코드 생성은 두 단계로 나누어집니다. 먼저 입력 내용을 기반으로 QR 코드 이미지를 생성한 다음 로컬 로고 이미지를 읽고, 이미지 처리를 통해 로고가 포함된 QR 코드를 생성합니다. 이 글은 이를 소개하고 참고할만한 가치가 아주 좋습니다.
로고가 포함된 QR 코드를 생성하는 방법은 두 단계로 나누어집니다. 먼저, 기반으로 QR 코드 이미지를 생성합니다. 입력 내용을 입력한 후 로컬 로고 이미지를 읽고 이미지 처리를 통해 로고가 포함된 QR 코드를 생성합니다.
생성된 QR코드 효과는 다음과 같습니다.
아래에는 QR코드 생성 클래스인 QRCodeHelper.cs가 직접 게시되어 있고, CreateQRCodeWithLogo 메소드가 직접 호출됩니다. , 해당 매개변수는 비트맵 유형 데이터를 반환합니다. 반환된 데이터를 이미지 컨트롤에 직접 바인딩합니다. 웹인 경우 먼저 이미지를 지정된 주소에 저장할 수 있습니다.
/// <summary> /// 生成带logo二维码 /// </summary> public class QRCodeHelper {/// <summary> /// 创建二维码 /// </summary> /// <param name="content"></param> /// <param name="size"></param> /// <returns></returns> public static Bitmap Create(string content) { try { //var options = new QrCodeEncodingOptions //{ // DisableECI = true, // CharacterSet = "UTF-8", // Width = size, // Height = size, // Margin = 0, // ErrorCorrection = ErrorCorrectionLevel.H //}; //var writer = new BarcodeWriter(); //writer.Format = BarcodeFormat.QR_CODE; //writer.Options = options; //var bmp = writer.Write(content); //return bmp; QRCodeEncoder qRCodeEncoder = new QRCodeEncoder(); qRCodeEncoder.QRCodeEncodeMode = QRCodeEncoder.ENCODE_MODE.BYTE;//设置二维码编码格式 qRCodeEncoder.QRCodeScale = 4;//设置编码测量度 qRCodeEncoder.QRCodeVersion = 7;//设置编码版本 qRCodeEncoder.QRCodeErrorCorrect = QRCodeEncoder.ERROR_CORRECTION.M;//设置错误校验 Bitmap image = qRCodeEncoder.Encode(content); return image; } catch (Exception ex) { return null; } } /// <summary> /// 获取本地图片 /// </summary> /// <param name="fileName"></param> /// <returns></returns> private static Bitmap GetLocalLog(string fileName) { Bitmap newBmp = new Bitmap(fileName); //Bitmap bmp = new Bitmap(newBmp); return newBmp; } /// <summary> /// 生成带logo二维码 /// </summary> /// <returns></returns> public static Bitmap CreateQRCodeWithLogo(string content, string logopath) { //生成二维码 Bitmap qrcode = Create(content); //生成logo Bitmap logo = GetLocalLog(logopath); ImageUtility util = new ImageUtility(); Bitmap finalImage = util.MergeQrImg(qrcode, logo); return finalImage; } }
다음은 인터넷에 있는 이미지 처리 클래스입니다. ImageUtility.cs
public class ImageUtility { #region 合并用户QR图片和用户头像 /// <summary> /// 合并用户QR图片和用户头像 /// </summary> /// <param name="qrImg">QR图片</param> /// <param name="headerImg">用户头像</param> /// <param name="n"></param> /// <returns></returns> public Bitmap MergeQrImg(Bitmap qrImg, Bitmap headerImg, double n = 0.23) { int margin = 10; float dpix = qrImg.HorizontalResolution; float dpiy = qrImg.VerticalResolution; var _newWidth = (10 * qrImg.Width - 36 * margin) * 1.0f / 36; var _headerImg = ZoomPic(headerImg, _newWidth / headerImg.Width); //处理头像 int newImgWidth = _headerImg.Width + margin; Bitmap headerBgImg = new Bitmap(newImgWidth, newImgWidth); headerBgImg.MakeTransparent(); Graphics g = Graphics.FromImage(headerBgImg); g.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.HighQualityBicubic; g.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality; g.Clear(Color.Transparent); Pen p = new Pen(new SolidBrush(Color.White)); Rectangle rect = new Rectangle(0, 0, newImgWidth - 1, newImgWidth - 1); using (GraphicsPath path = CreateRoundedRectanglePath(rect, 1)) { g.DrawPath(p, path); g.FillPath(new SolidBrush(Color.White), path); } //画头像 Bitmap img1 = new Bitmap(_headerImg.Width, _headerImg.Width); Graphics g1 = Graphics.FromImage(img1); g1.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.HighQualityBicubic; g1.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality; g1.Clear(Color.Transparent); Pen p1 = new Pen(new SolidBrush(Color.Gray)); Rectangle rect1 = new Rectangle(0, 0, _headerImg.Width - 1, _headerImg.Width - 1); using (GraphicsPath path1 = CreateRoundedRectanglePath(rect1, 1)) { g1.DrawPath(p1, path1); TextureBrush brush = new TextureBrush(_headerImg); g1.FillPath(brush, path1); } g1.Dispose(); PointF center = new PointF((newImgWidth - _headerImg.Width) / 2, (newImgWidth - _headerImg.Height) / 2); g.DrawImage(img1, center.X, center.Y, _headerImg.Width, _headerImg.Height); g.Dispose(); Bitmap backgroudImg = new Bitmap(qrImg.Width, qrImg.Height); backgroudImg.MakeTransparent(); backgroudImg.SetResolution(dpix, dpiy); headerBgImg.SetResolution(dpix, dpiy); Graphics g2 = Graphics.FromImage(backgroudImg); g2.Clear(Color.Transparent); g2.DrawImage(qrImg, 0, 0); PointF center2 = new PointF((qrImg.Width - headerBgImg.Width) / 2, (qrImg.Height - headerBgImg.Height) / 2); g2.DrawImage(headerBgImg, center2); g2.Dispose(); return backgroudImg; } #endregion #region 图形处理 /// <summary> /// 创建圆角矩形 /// </summary> /// <param name="rect">区域</param> /// <param name="cornerRadius">圆角角度</param> /// <returns></returns> private GraphicsPath CreateRoundedRectanglePath(Rectangle rect, int cornerRadius) { //下午重新整理下,圆角矩形 GraphicsPath roundedRect = new GraphicsPath(); roundedRect.AddArc(rect.X, rect.Y, cornerRadius * 2, cornerRadius * 2, 180, 90); roundedRect.AddLine(rect.X + cornerRadius, rect.Y, rect.Right - cornerRadius * 2, rect.Y); roundedRect.AddArc(rect.X + rect.Width - cornerRadius * 2, rect.Y, cornerRadius * 2, cornerRadius * 2, 270, 90); roundedRect.AddLine(rect.Right, rect.Y + cornerRadius * 2, rect.Right, rect.Y + rect.Height - cornerRadius * 2); roundedRect.AddArc(rect.X + rect.Width - cornerRadius * 2, rect.Y + rect.Height - cornerRadius * 2, cornerRadius * 2, cornerRadius * 2, 0, 90); roundedRect.AddLine(rect.Right - cornerRadius * 2, rect.Bottom, rect.X + cornerRadius * 2, rect.Bottom); roundedRect.AddArc(rect.X, rect.Bottom - cornerRadius * 2, cornerRadius * 2, cornerRadius * 2, 90, 90); roundedRect.AddLine(rect.X, rect.Bottom - cornerRadius * 2, rect.X, rect.Y + cornerRadius * 2); roundedRect.CloseFigure(); return roundedRect; } /// <summary> /// 图片按比例缩放 /// </summary> private Image ZoomPic(Image initImage, double n) { //缩略图宽、高计算 double newWidth = initImage.Width; double newHeight = initImage.Height; newWidth = n * initImage.Width; newHeight = n * initImage.Height; //生成新图 //新建一个bmp图片 System.Drawing.Image newImage = new System.Drawing.Bitmap((int)newWidth, (int)newHeight); //新建一个画板 System.Drawing.Graphics newG = System.Drawing.Graphics.FromImage(newImage); //设置质量 newG.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.HighQualityBicubic; newG.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality; //置背景色 newG.Clear(Color.Transparent); //画图 newG.DrawImage(initImage, new System.Drawing.Rectangle(0, 0, newImage.Width, newImage.Height), new System.Drawing.Rectangle(0, 0, initImage.Width, initImage.Height), System.Drawing.GraphicsUnit.Pixel); newG.Dispose(); return newImage; } /// <summary> /// 创建缩略图 /// </summary> /// <param name="b"></param> /// <param name="destHeight"></param> /// <param name="destWidth"></param> /// <returns></returns> public static Bitmap GetThumbnail(Bitmap b, int destHeight, int destWidth) { System.Drawing.Image imgSource = b; System.Drawing.Imaging.ImageFormat thisFormat = imgSource.RawFormat; int sW = 0, sH = 0; // 按比例缩放 int sWidth = imgSource.Width; int sHeight = imgSource.Height; if (sHeight > destHeight || sWidth > destWidth) { if ((sWidth * destHeight) > (sHeight * destWidth)) { sW = destWidth; sH = (destWidth * sHeight) / sWidth; } else { sH = destHeight; sW = (sWidth * destHeight) / sHeight; } } else { sW = sWidth; sH = sHeight; } Bitmap outBmp = new Bitmap(destWidth, destHeight); Graphics g = Graphics.FromImage(outBmp); g.Clear(Color.Transparent); // 设置画布的描绘质量 g.CompositingQuality = CompositingQuality.HighQuality; g.SmoothingMode = SmoothingMode.HighQuality; g.InterpolationMode = InterpolationMode.HighQualityBicubic; g.DrawImage(imgSource, new Rectangle((destWidth - sW) / 2, (destHeight - sH) / 2, sW, sH), 0, 0, imgSource.Width, imgSource.Height, GraphicsUnit.Pixel); g.Dispose(); // 以下代码为保存图片时,设置压缩质量 EncoderParameters encoderParams = new EncoderParameters(); long[] quality = new long[1]; quality[0] = 100; EncoderParameter encoderParam = new EncoderParameter(System.Drawing.Imaging.Encoder.Quality, quality); encoderParams.Param[0] = encoderParam; imgSource.Dispose(); return outBmp; } #endregion }
위 내용은 C#을 사용하여 로고가 있는 QR 코드를 생성하는 샘플 코드 공유의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

C# 및 .NET 런타임은 개발자가 효율적이고 강력하며 크로스 플랫폼 개발 기능을 강화하기 위해 긴밀히 협력합니다. 1) C#은 .NET 프레임 워크와 완벽하게 통합하도록 설계된 유형 안전 및 객체 지향 프로그래밍 언어입니다. 2) .NET 런타임은 C# 코드 실행을 관리하고, 쓰레기 수집, 유형 안전 및 기타 서비스를 제공하며, 효율적이고 크로스 플랫폼 운영을 보장합니다.

C# .NET 개발을 시작하려면 다음과 같은 것이 필요합니다. 1. C#의 기본 지식과 .NET 프레임 워크의 핵심 개념을 이해하십시오. 2. 변수, 데이터 유형, 제어 구조, 기능 및 클래스의 기본 개념을 마스터하십시오. 3. LINQ 및 비동기 프로그래밍과 같은 C#의 고급 기능을 배우십시오. 4. 일반적인 오류에 대한 디버깅 기술 및 성능 최적화 방법에 익숙해 지십시오. 이러한 단계를 통해 C#.NET의 세계를 점차적으로 침투하고 효율적인 응용 프로그램을 작성할 수 있습니다.

C#과 .NET의 관계는 분리 할 수 없지만 같은 것은 아닙니다. C#은 프로그래밍 언어이며 .NET은 개발 플랫폼입니다. C#은 코드를 작성하고 .NET의 중간 언어 (IL)로 컴파일하고 .NET 런타임 (CLR)에 의해 실행되는 데 사용됩니다.

C#.NET은 여러 응용 프로그램 개발을 지원하는 강력한 도구 및 라이브러리를 제공하기 때문에 여전히 중요합니다. 1) C#은 .NET 프레임 워크를 결합하여 개발 효율적이고 편리하게 만듭니다. 2) C#의 타입 안전 및 쓰레기 수집 메커니즘은 장점을 향상시킵니다. 3) .NET은 크로스 플랫폼 실행 환경과 풍부한 API를 제공하여 개발 유연성을 향상시킵니다.

C#.NETISVERSATILEFORBOTHWEBBANDDESKTOPDEVENTROMMENT.1) FORWEB, useASP.NETFORRICHINTERFACES.3) FORDESKTOP.3) USEXAMARINFORCROSS-PLATFORMDEEVENTRIMMENT, LINABILEDEV, MACODEDEV, and MACODEDOWS, 및 MACODEDOWS.

C# 및 .NET는 지속적인 업데이트 및 최적화를 통해 신흥 기술의 요구에 적응합니다. 1) C# 9.0 및 .NET5는 레코드 유형 및 성능 최적화를 소개합니다. 2) .NETCORE는 클라우드 네이티브 및 컨테이너화 된 지원을 향상시킵니다. 3) ASP.NETCORE는 최신 웹 기술과 통합됩니다. 4) ML.NET는 기계 학습 및 인공 지능을 지원합니다. 5) 비동기 프로그래밍 및 모범 사례는 성능을 향상시킵니다.

C#.netissuitable forenterprise-levelapplications는 richlibraries, androbustperformance, 그러나 itmaynotbeidealforcross-platformdevelopmentorwhenrawspeediscritical, wherelanguagesslikerustorthightordogrordogrognegrognegrognegrognecross-platformdevelopmentor.

.NET에서 C#의 프로그래밍 프로세스에는 다음 단계가 포함됩니다. 1) C# 코드 작성, 2) 중간 언어 (IL)로 컴파일하고 .NET 런타임 (CLR)에 의해 실행됩니다. .NET에서 C#의 장점은 현대적인 구문, 강력한 유형 시스템 및 .NET 프레임 워크와의 긴밀한 통합으로 데스크탑 응용 프로그램에서 웹 서비스에 이르기까지 다양한 개발 시나리오에 적합합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

드림위버 CS6
시각적 웹 개발 도구
