Photoshop样式的角度和高度选择器控件

photoshop样式的角度和高度选择器控件

Photoshop样式的角度和高度选择器控件

简介

Adobe Photoshop有两个非常专业的用来设置如投影、斜面与浮雕等特效的控件:一个是角度选择器,另一个是角度与高度选择器(如上图所示)。

本文将带领读者创建两个自定义控件,来模仿Photoshop中这两个控件的外观和行为。

基础知识——数学

毕达哥拉斯定理

(即勾股定理,为尊重原文,以下简称毕氏定理。尽管有点绕口。——野比注)

利用毕氏定理,我们可以计算直角三角形的斜边(最长边)。计算公式为Photoshop样式的角度和高度选择器控件 。这样,斜边c就等于Photoshop样式的角度和高度选择器控件

单位圆

鉴于接下来的工作和角度及圆有关,我们先熟悉一下单位圆的形式是很有好处的。单位圆就是以(0,0)为圆心,半径为1的圆。在常规网格(指画布——野比注)中,0度(的坐标)从(1,0)这点(右)开始,按逆时针方向增大。因此,90度是(0,1),180度是(-1,0),270度是(0,-1),最后360度和0点重合。

三角函数

这里我们只需要知道三个基本的三角函数:sin、cos和tan(正弦、余弦和正切——野比注)。如果我们还记得SOH-CAH-TOA(译注+)的话,我们就知道,(直角)三角形的正弦等于对边比上斜边,余弦等于邻边比上斜边,正切等于对边比上邻边。

同样,我们知道反三角函数用来计算未知角度。

译注+:

SOH-CAH-TOA是老外用来记忆三角函数的口诀。其中:O为opposite(对边),H为Hypotenuse(斜边),A为Adjacent(邻边)。 

SOH:  Sine = Opposite ÷ Hypotenuse

CAH:  Cosine = Adjacent ÷ Hypotenuse

TOA:  Tangent = Opposite ÷ Adjacent

常用函数

我们制作的自定义控件都会用到下面这两个重要的函数(方法): 

一个函数接收角度和半径作为参数,返回围绕某个原点的相应点位置。(简单来说,就是把角度转换为点)

一个完成相反的功能,以点(X, Y)作为参数,找到最匹配的角度。

第一个函数要简单些:

private PointF DegreesToXY(float degrees, float radius, Point origin)  {    PointF xy = new PointF();    double radians = degrees * Math.PI / 180.0;    xy.X = (float)Math.Cos(radians) * radius + origin.X;    xy.Y = (float)Math.Sin(-radians) * radius + origin.Y;    return xy;  }

登录后复制

 要注意的是首先我们需要把角度换算成弧度。一般来说,我们只需要在单位圆中进行研究:

Photoshop样式的角度和高度选择器控件

该函数已知角度和半径,利用三角函数,我们算出X和Y值,然后在加上给定的原点初始坐标即可。

还应看到,函数代码中用到的是Y分量的负值,这是因为计算机显示器上网格是上下颠倒的(向下为正)。

第二个函数的功能是把用户在控件上点击的点位置转换为相应的角度值。这稍稍麻烦点,因为我们不得不考虑添加一些东西。限于文章篇幅,我这里贴出部分代码:

private float XYToDegrees(Point xy, Point origin)  {    double angle = 0.0;    if (xy.Y  origin.X)      {        angle = (double)(xy.X - origin.X) / (double)(origin.Y - xy.Y);        angle = Math.Atan(angle);        angle = 90.0 - angle * 180.0 / Math.PI;      }      else if (xy.X  origin.Y)    {      //如此这般    }    if (angle > 180) angle -= 360; //控制角度范围    return (float)angle;  }

登录后复制

该函数主要通过检查鼠标相对中心点的位置,确定其所在象限。一旦我们知道了象限,就可以利用三角函数(反正切)计算出角度。 

如果角度大于180度,则减去360度。这样就和Photoshop一样,把角度控制在-180度和180度之间。当然,这一步可以不做,不加这行代码控件一样能用。

制作控件

绘制控件

这两个控件的背景相同: 

用宽度为2的Pen绘制外圈圆

用40%(约100)不透明度的白色填充

控件中心是3×3像素的正方形

protected override void OnPaint(PaintEventArgs e)  {    //...      //Draw    g.SmoothingMode = SmoothingMode.AntiAlias;    g.DrawEllipse(outline, drawRegion);    g.FillEllipse(fill, drawRegion);      //...光标     g.SmoothingMode = SmoothingMode.HighSpeed;     g.FillRectangle(Brushes.Black, originSquare);      //...  }

登录后复制

注意SmoothMode属性。在绘制圆圈时将该属性设置为AntiAlias(抗锯齿),这样看起来既光滑又专业。但是如果画正方形时也用抗锯齿,就会显得模糊难看,所以将SmoothMode设置为HighSpeed(高速),这样画出的正方形边缘整齐犀利。 

根据控件不同,光标也有不同绘制方法。角度选择器比较简单,只需要从圆心到DegreesToXY函数返回的点连一条直线即可。角度与高度选择器则是在这点上绘制一个1×1的矩形,然后在周围绘制一个十字型光标。

处理用户点击

多亏我们有了XYToDegrees函数,处理用户点击变得特别简单。为了让我们的控件用起来和Photoshop一模一样,我们需要设置MouseDown和MouseMove事件。这样,各项数值将实时更新。这里是一个附注函数的代码:

private int findNearestAngle(Point mouseXY)  {    int thisAngle = (int)XYToDegrees(mouseXY, origin);    if (thisAngle != 0)      return thisAngle;    else      return -1;  }

登录后复制

 高度控件需要额外的处理,就是找到中心点和鼠标点击点的距离:

private int findAltitude(Point mouseXY)  {    float distance = getDistance(mouseXY, origin);    int alt = 90 - (int)(90.0f * (distance / origin.X));    if (alt < 0) alt = 0;    return alt;  }

登录后复制

 在Photoshop中,选择点(指鼠标点击点)在圆心时,高度为90,在边缘处则为0。这样,我们可以通过找到点击点到圆心距离和半径高度比值来计算出高度。然后,用90减去该值(实际上是按90到0来翻转一下)。

自定义事件

为了让我们的自定义控件更加专业,需要控件能够在数值发生变化时以编程方式进行提醒。这就是我们要设置事件的原因。

例如,像这样给角度变化添加一个事件:

public delegate void AngleChangedDelegate();  public event AngleChangedDelegate AngleChanged;

登录后复制

然后,我们要做的就是每次变更Angle属性时,调用AngleChanged()(需要先判断是否为null)。

限制与改进

闪烁

没有闪烁!只需要在制作控件时设置DoubleBuffered属性为true,.NET Framework 2.0会处理剩下的工作,保证控件能流畅的重绘。

尺寸

因为控件使用基于半径(圆)的数学计算方法,因此需要保证控件的长度和宽度相等。

颜色

我是照着Photoshop的样子来的,所以并没包含背景颜色、外圈颜色这些属性。但是,浏览下代码,你会发现改成你喜欢的颜色或者让颜色可以动态修改并不是什么难事。

结论

我建议你下载项目文件(或者至少下载DEMO),这样你可以看到这俩控件用起来很爽。

协议

本文及有关代码、程序均基于CPOL(Codeproject Open License)协议。

更多Photoshop样式的角度和高度选择器控件 相关文章请关注PHP中文网!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2983529.html

(0)
上一篇 2025年3月12日 04:27:54
下一篇 2025年3月7日 21:28:23

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • OpenCV成长之路(3):模仿PhotoShop中魔术棒工具

    本文的主题实际上是图像的颜色空间的转换,借助一个颜色选取程序来说明opencv中颜色转换函数的用法以及一些注意事项。 一、几种常见的颜色空间: RGB颜色空间:RGB采用加法混色法,因为它是描述各种“光”通过何种比例来产生颜色。光线从暗黑开…

    2025年3月12日
    200
  • 前端工程师技能之photoshop巧用系列第一篇——准备篇

    前面的话   photoshop是前端工程师无法回避的一个软件,这个软件本身很强大,但我们仅仅需要通过这个工具来完成基本的切图工作即可。本文将开始photoshop巧用系列的第一篇——准备篇   作用   我们为什么要去切图呢?这就需要说到…

    2025年3月12日 编程技术
    200
  • 更改Photoshop 语言为英语(无需语言包)

    因为有时看国外教程时,手头上的ps是中文的而教程里的界面是英文的,而且中英菜单顺序在某些地方是不一样的,所以很不方便。 终于找到一个非常完美的方法可以把界面换成英文,而且不需任何语言包。 并且试了在最新的Photoshop CC版本中可用。…

    2025年3月12日
    200
  • 带节点曲线,鼠标可拖动节点调整曲线,类似Photoshop

    photoshop中比较常用的一个功能就是曲线调整,如图 通过鼠标添加、删除、拖动曲线节点,这样即可调整图像参数。这个功能就其思路来说(这里只考虑曲线本身,数据存储等不在此列),是比较简单的: 曲线由一组Point表示节点 鼠标移动节点实际…

    2025年3月12日
    200
  • Photoshop操作秘籍

    1、需要多层选择时,可以先用选择工具选定文件中的区域,屏幕会出现一个选择虚框;接着按住键盘上的”Alt”键,当光标变成一个右下角带一小”-”的大”+”号时,这表示减少被…

    编程技术 2025年3月12日
    200
  • Photoshop 小技巧集锦

     81. 如果你用“path”画了一条路径,而鼠标现在的状态又是钢笔的话,你只按下小键盘上的回车键(记住是小 键盘上的回车,不是主键盘上的!),那么路径就马上会变为“选取区”了。   82. 如果你用钢笔工具画了一条路径,而你现在鼠标的状态…

    编程技术 2025年3月12日
    200
  • Photoshop-蒙版

         photoshop蒙版原理:  photoshop蒙板是将不同灰度色值转化为不同的透明度,并作用到它所在的图层,使图层不同部位透明度产生相应的变化。黑色为完全透明,白色为完全不透明。     Photoshop蒙版的优点:   1…

    2025年3月12日 编程技术
    200
  • PhotoShop常用快捷键

    Photoshop常用快捷键: 图01 图02 图03 图04 图05     快捷键 PS快捷键是Photoshop为了提高绘图速度定义的快捷方式,它用一个或几个简单的字母来代替常用的命令。 多种工具共用一个快捷键的可同时按【Shift】…

    2025年3月12日 编程技术
    200
  • photoshop中的图层蒙版是什么

    蒙板、通道、图层是photoshop学习中的三只拦路虎。但我认为之所以初学者觉得它们很难,可能是很多人在讲述应用的时候把简单的问题给搞的复杂化了。比如图层蒙板,本来是个非常简单的问题,但搞不明白的人非常多。 图层蒙版可以理解为在当前图层上面…

    编程技术 2025年3月12日
    200
  • Photoshop CS6 基础知识

    photoshop cs6  基础知识  新建  练习 宽度72, 像素厘米         颜色模板分类  RGB  CMYK        背景内容        色彩三要素:色相,饱和度,明度(亮度)                 …

    2025年3月12日 编程技术
    200

发表回复

登录后才能评论