C#软件开发实例.私人订制自己的屏幕截图工具(九)使用自己定义光标,QQ截图时的光标

时间:2023-03-09 03:13:37
C#软件开发实例.私人订制自己的屏幕截图工具(九)使用自己定义光标,QQ截图时的光标

版权声明:本文为 testcs_dn(微wx笑) 原创文章,非商用*转载-保持署名-注明出处,谢谢。 https://blog.****.net/testcs_dn/article/details/30835107

本实例所有文章文件夹

在使用QQ的截图功能的时候,是不是认为它的光标非常酷呢?今天就说一下怎么应用自己定义光标,在我们的截图工具中使用QQ截图的光标。

打开资源:

C#软件开发实例.私人订制自己的屏幕截图工具(九)使用自己定义光标,QQ截图时的光标

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdGVzdGNzX2Ru/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="" />

切换到文件资源视图:

C#软件开发实例.私人订制自己的屏幕截图工具(九)使用自己定义光标,QQ截图时的光标

打开资源文件文件夹,将光标文件拷贝到此文件夹下:

C#软件开发实例.私人订制自己的屏幕截图工具(九)使用自己定义光标,QQ截图时的光标

所需光标文件下载:C#软件开发实例.私人订制自己的屏幕截图工具中使用的光标文件

选中Resources文件夹。刷新,显示出刚刚复制进来的光标文件:

C#软件开发实例.私人订制自己的屏幕截图工具(九)使用自己定义光标,QQ截图时的光标

选中光标文件。拖动到资源的文件视图中:

C#软件开发实例.私人订制自己的屏幕截图工具(九)使用自己定义光标,QQ截图时的光标

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdGVzdGNzX2Ru/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="" />

资源资源名称中的单词第一个字母改为大写。

光标预览:

C#软件开发实例.私人订制自己的屏幕截图工具(九)使用自己定义光标,QQ截图时的光标

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdGVzdGNzX2Ru/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="" />

在Form1类中加入私有变量:

        #region 自己定义光标
System.Windows.Forms.Cursor cursorCross = null;
System.Windows.Forms.Cursor cursorDefault = null;
System.Windows.Forms.Cursor cursorText = null;
System.Windows.Forms.Cursor cursorColor = null;
#endregion

加入WindowsAPI声明:

        [DllImport("user32.dll")]
private static extern IntPtr LoadCursorFromFile(string fileName);

加入从已有资源中获得光标的方法:

        /// <summary>
/// 从已有资源中获得光标
/// </summary>
/// <param name="resource"></param>
/// <returns></returns>
public static Cursor getCursorFromResource(byte[] resource)
{
byte[] b = resource;
FileStream fileStream = new FileStream("cursorData.dat", FileMode.Create);
fileStream.Write(b, 0, b.Length);
fileStream.Close();
Cursor cur = new Cursor(LoadCursorFromFile("cursorData.dat"));
return cur;
}

加入窗体初始化事件处理程序。加入自己定义光标:

        /// <summary>
/// 窗体初始化事件处理程序
/// </summary>
private void Form1_Init()
{
this.isCuting = false;
this.beginPoint = new Point(0, 0);
this.endPoint = new Point(0, 0); cursorDefault = getCursorFromResource(Properties.Resources.Cursor_Default);
cursorCross = getCursorFromResource(Properties.Resources.Cursor_Cross);
cursorText = getCursorFromResource(Properties.Resources.Cursor_Text);
cursorColor = getCursorFromResource(Properties.Resources.Cursor_Color);
}

设置默认光标,处理光标状态:

在ShowForm方法的else条件中加入:

this.Cursor = cursorDefault;

在ExitCutImage方法中加入代码:

this.Cursor = cursorDefault;

加入鼠标进入Form1窗体事件处理程序:

        /// <summary>
/// 鼠标进入Form1窗体事件处理程序
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void Form1_MouseEnter(object sender, EventArgs e)
{
this.Cursor = cursorDefault;
}

Form1的构造函数中加入代码:

Form1_Init();

Ok,编译。截图看看效果吧。

这里加入了多个光标文件,可是仅仅用到了一个,其他的在以后加入的功能中会使用到。