C#画像処理描画公式シール

Nov 17, 2016 pm 01:59 PM
c#

最近画像処理を学び始めました。学んだことを少し記録します。書き終わったら、小さなソフトウェアをリリースします〜

これは、公式シールを描くことです。

#region 绘制公章
        private void simpleButton_绘制公章_Click(object sender, EventArgs e)
        {
            int tem_Line = 0;  //圆的直径
            int circularity_W = 5; //画笔的粗细
            string star_Str = "★";  //星星
            Font star_Font = new Font("Arial", 30, FontStyle.Regular);//设置星号的字体样式

            #region 画圆

            if (panel_绘制公章.Height > panel_绘制公章.Width)  //如果panel控件的高度大于等于宽度
            {
                tem_Line = panel_绘制公章.Width;  //设置宽度为圆的直径
            }
            else
            {
                tem_Line = panel_绘制公章.Height;  //设置高度为圆的直径
            }
            //设置圆的绘制区域=>现在是正方形的区域
            rect = new Rectangle(circularity_W, circularity_W, tem_Line - 2 * circularity_W, tem_Line - 2 * circularity_W);

            //补充:Graphics必须有载体,也就是在哪里绘
            //所以必须是this.CreateGraphics或者Panel..CreateGraphics等格式
            Graphics g = panel_绘制公章.CreateGraphics();//实例化Graphics类
            //消除绘制图形的锯齿
            g.SmoothingMode = SmoothingMode.AntiAlias;  //System.Drawing.Drawing2D;           
            g.Clear(Color.White);  //以白色清空panel1控件的背景,防止重复画           
            Pen myPen = new Pen(Color.Red, circularity_W);  //设置画笔(颜色和粗细)
            g.DrawEllipse(myPen, rect);  //绘制圆

            #endregion

            #region 画星星

            SizeF Var_Size = new SizeF(rect.Width, rect.Height);  //实例化SizeF类
            Var_Size = g.MeasureString(star_Str, star_Font);  //对指定字符串进行测量

            //正中间的位置绘制星号
            float star_x = (rect.Width / 2F) + circularity_W - Var_Size.Width / 2F;
            float star_y = rect.Height / 2F - Var_Size.Width / 2F;
            g.DrawString(star_Str, star_Font, myPen.Brush, new PointF(star_x, star_y));
            
            #endregion

            #region 画文字

            Var_Size = g.MeasureString("本人专用章", Var_Font);//对指定字符串进行测量

            //绘制文字:在中间,但是在星星下面
            float m = (rect.Width / 2F) + circularity_W - Var_Size.Width / 2F;
            float n = rect.Height / 2F + Var_Size.Height * 2;
            g.DrawString("本人专用章", Var_Font, myPen.Brush, new PointF(m, n));

            int len = 0;
            if (inputWords != null) //如果没有输入文字,加判断
            {
                len = inputWords.Length;//获取字符串的长度
            }

            float angle = 180;//设置文字的初始旋转角度
            
            float change = 0;

            if (len > 1) //一个字的需要特殊处理
            {
                change = 180 / (len - 1);
            }
            for (int i = 0; i < len; i++)//将文字以指定的弧度进行绘制
            {
                if (len > 1)
                {
                    //相当于把坐标系移动到了正中间
                    float x = (tem_Line + circularity_W / 2) / 2;
                    float y = (tem_Line + circularity_W / 2) / 2;
                    //将指定的平移添加到g的变换矩阵前         
                    g.TranslateTransform(x, y);
                    g.RotateTransform(angle);//将指定的旋转用于g的变换矩阵   
                    Brush myBrush = Brushes.Red;//定义画刷

                    //需要注意,这时文字的位置的坐标位置是以新的坐标系为基础得到的
                    float words_x = tem_Line / 2 - 6 * circularity_W;
                    float words_y = 0;
                    g.DrawString(inputWords.Substring(i, 1), Var_Font, myBrush, words_x, words_y);//显示旋转文字
                    g.ResetTransform();//将g的全局变换矩阵重置为单位矩阵=>对应TranslateTransform,相当于恢复操作
                    angle += change;//设置下一个文字的角度

                }
                else
                {
                    //输入的文字为一个时候是特殊情况,单独考虑
                    float x = (tem_Line + circularity_W / 2) / 2;
                    float y = (tem_Line + circularity_W / 2) / 2;       
                    g.TranslateTransform(x, y);
                    g.RotateTransform(0);  
                    Brush myBrush = Brushes.Red;
                    float words_x = -circularity_W*3;
                    float words_y = -(tem_Line / 2 - 2 * circularity_W);
                    g.DrawString(inputWords.Substring(i, 1), Var_Font, myBrush, words_x, words_y);
                    g.ResetTransform();
                }
                
            }

            #endregion

        }

        private void simpleButton2_Click(object sender, EventArgs e)
        {
            inputWords = textBox_文字.Text;
            MessageBox.Show("保存成功!");
        }
#endregion
ログイン後にコピー

効果プレビュー:

C#画像処理描画公式シール

C#画像処理描画公式シール

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

C# を使用した Active Directory C# を使用した Active Directory Sep 03, 2024 pm 03:33 PM

C# を使用した Active Directory のガイド。ここでは、Active Directory の概要と、C# での動作方法について、構文と例とともに説明します。

C# シリアル化 C# シリアル化 Sep 03, 2024 pm 03:30 PM

C# シリアル化のガイド。ここでは、C# シリアル化オブジェクトの導入、手順、作業、例についてそれぞれ説明します。

C# の乱数ジェネレーター C# の乱数ジェネレーター Sep 03, 2024 pm 03:34 PM

C# の乱数ジェネレーターのガイド。ここでは、乱数ジェネレーターの仕組み、擬似乱数の概念、安全な数値について説明します。

C# データ グリッド ビュー C# データ グリッド ビュー Sep 03, 2024 pm 03:32 PM

C# データ グリッド ビューのガイド。ここでは、SQL データベースまたは Excel ファイルからデータ グリッド ビューをロードおよびエクスポートする方法の例について説明します。

C# のパターン C# のパターン Sep 03, 2024 pm 03:33 PM

C# のパターンのガイド。ここでは、C# のパターンの概要と上位 3 種類について、その例とコード実装とともに説明します。

C# の素数 C# の素数 Sep 03, 2024 pm 03:35 PM

C# の素数ガイド。ここでは、C# における素数の導入と例を、コードの実装とともに説明します。

C# の階乗 C# の階乗 Sep 03, 2024 pm 03:34 PM

C# の Factorial のガイド。ここでは、C# での階乗の概要について、さまざまな例とコード実装とともに説明します。

マルチスレッドと非同期C#の違い マルチスレッドと非同期C#の違い Apr 03, 2025 pm 02:57 PM

マルチスレッドと非同期の違いは、マルチスレッドが複数のスレッドを同時に実行し、現在のスレッドをブロックせずに非同期に操作を実行することです。マルチスレッドは計算集約型タスクに使用されますが、非同期はユーザーインタラクションに使用されます。マルチスレッドの利点は、コンピューティングのパフォーマンスを改善することですが、非同期の利点はUIスレッドをブロックしないことです。マルチスレッドまたは非同期を選択することは、タスクの性質に依存します。計算集約型タスクマルチスレッド、外部リソースと相互作用し、UIの応答性を非同期に使用する必要があるタスクを使用します。

See all articles