diff --git a/Bin/Debug/CommonControls/.NET4/OnLineUpgradeConfig.exe b/Bin/Debug/CommonControls/.NET4/OnLineUpgradeConfig.exe index 770e48e..1474057 100644 Binary files a/Bin/Debug/CommonControls/.NET4/OnLineUpgradeConfig.exe and b/Bin/Debug/CommonControls/.NET4/OnLineUpgradeConfig.exe differ diff --git a/Bin/Debug/CommonControls/.NET4/RaUI.dll b/Bin/Debug/CommonControls/.NET4/RaUI.dll index a688604..94d66d6 100644 Binary files a/Bin/Debug/CommonControls/.NET4/RaUI.dll and b/Bin/Debug/CommonControls/.NET4/RaUI.dll differ diff --git a/Bin/Debug/CommonControls/.NET4/RaUI.xml b/Bin/Debug/CommonControls/.NET4/RaUI.xml index e9e3ae2..56da64a 100644 --- a/Bin/Debug/CommonControls/.NET4/RaUI.xml +++ b/Bin/Debug/CommonControls/.NET4/RaUI.xml @@ -1251,11 +1251,16 @@ 取消事件 + + + 是否跳过相同文件,默认不跳过(根据文件大小和修改时间来判断) + + 大文件按流复制文件,支持自动创建目标文件夹。 true:复制成功 false:复制失败 - 原始文件路径 + 原始文件路径 复制目标文件路径 携带的参数(可选) @@ -2039,6 +2044,25 @@ 目标文件夹 返回复制操作是否成功的标识,成功返回0,负数表示复制失败的文件数量。1表示源文件夹不存在 + + + 复制或剪切文件列表到剪切板 + + + + + + + 复制文件列表到剪切板 + + + + + + 剪切文件列表到剪切板 + + + 重命名一个文件为新名称,建议您使用更方便的Microsoft.VisualBasic.FileSystem.ReName();替换该方法 @@ -13834,6 +13858,11 @@ + + + 是否将时间类型转为时间戳 + + 输出多条件搜索。 @@ -13848,6 +13877,12 @@ + + + 根据输入的内容,生成Json数据 + + + 获取插入SQL语句 @@ -15902,27 +15937,44 @@ - - Shell - + + 获得桌面 Shell + + + + + 获得桌面 Shell + + + + + 获取路径 + + + + + 获取显示名称 + + + + + 根据 PIDL 获取显示名称 + + + + + 获取特殊文件夹的路径 + 根据路径获取 IShellFolder 和 PIDL - + - + 根据路径获取 IShellFolder - - - - - - - - @@ -16736,6 +16788,14 @@ + + + + + + + + 注册热键 @@ -18082,6 +18142,11 @@ 版本 + + + 版本类型 + + 更新日期 @@ -20148,10 +20213,11 @@ 鼠标移上时,显示提示 - + - 字体 + + @@ -20265,6 +20331,16 @@ 值1 + + + int值1 + + + + + long值1 + + Tag @@ -20897,6 +20973,52 @@ 热键文本框 + + + 清除按钮位置 + + + + + 热键文本位置 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -24633,6 +24755,11 @@ Chrome风格的多标签控件 + + + 获取或设置调整控件的选项卡大小的方式。 + + @@ -30255,12 +30382,12 @@ - Automatically sets the size of the label by content size + 根据内容大小自动设置标签的大小 - Automatically sets the height of the label by content height (width is not effected). + 根据内容高度自动设置标签的高度(宽度不受影响)。 @@ -54175,7 +54302,7 @@ Bounds of the cell The string to be drawn - 笔刷 + @@ -54198,6 +54325,37 @@ + + + Draw the given text and optional image in the "normal" fashion + + Graphics context to use for drawing + Bounds of the cell + + The string to be drawn + 笔刷 + + + + Draw the given text and optional image in the "normal" fashion + + Graphics context to use for drawing + Bounds of the cell + + The string to be drawn + + + + + + + 这里的r + + + + + + @@ -58222,6 +58380,79 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Wrapper over the control like TextBox. @@ -70106,79 +70337,6 @@ A visual indicator is displayed in the number margin. - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - A class for the Batch lexer. diff --git a/Bin/Debug/CommonControls/.NET4/rycUpdate.exe b/Bin/Debug/CommonControls/.NET4/rycUpdate.exe index 2c43f85..e8d2718 100644 Binary files a/Bin/Debug/CommonControls/.NET4/rycUpdate.exe and b/Bin/Debug/CommonControls/.NET4/rycUpdate.exe differ diff --git a/Bin/Release/CommonControls/.NET4/RaUI.dll b/Bin/Release/CommonControls/.NET4/RaUI.dll index 04abfac..e191e31 100644 Binary files a/Bin/Release/CommonControls/.NET4/RaUI.dll and b/Bin/Release/CommonControls/.NET4/RaUI.dll differ diff --git a/Bin/Release/CommonControls/.NET4/RaUI.xml b/Bin/Release/CommonControls/.NET4/RaUI.xml index 07c9e12..7197df0 100644 --- a/Bin/Release/CommonControls/.NET4/RaUI.xml +++ b/Bin/Release/CommonControls/.NET4/RaUI.xml @@ -1251,11 +1251,16 @@ 取消事件 + + + 是否跳过相同文件,默认不跳过(根据文件大小和修改时间来判断) + + 大文件按流复制文件,支持自动创建目标文件夹。 true:复制成功 false:复制失败 - 原始文件路径 + 原始文件路径 复制目标文件路径 携带的参数(可选) @@ -2039,6 +2044,25 @@ 目标文件夹 返回复制操作是否成功的标识,成功返回0,负数表示复制失败的文件数量。1表示源文件夹不存在 + + + 复制或剪切文件列表到剪切板 + + + + + + + 复制文件列表到剪切板 + + + + + + 剪切文件列表到剪切板 + + + 重命名一个文件为新名称,建议您使用更方便的Microsoft.VisualBasic.FileSystem.ReName();替换该方法 @@ -13834,6 +13858,11 @@ + + + 是否将时间类型转为时间戳 + + 输出多条件搜索。 @@ -13848,6 +13877,12 @@ + + + 根据输入的内容,生成Json数据 + + + 获取插入SQL语句 @@ -15902,27 +15937,44 @@ - - Shell - + + 获得桌面 Shell + + + + + 获得桌面 Shell + + + + + 获取路径 + + + + + 获取显示名称 + + + + + 根据 PIDL 获取显示名称 + + + + + 获取特殊文件夹的路径 + 根据路径获取 IShellFolder 和 PIDL - + - + 根据路径获取 IShellFolder - - - - - - - - @@ -16736,6 +16788,14 @@ + + + + + + + + 注册热键 @@ -18082,6 +18142,11 @@ 版本 + + + 版本类型 + + 更新日期 @@ -20148,10 +20213,11 @@ 鼠标移上时,显示提示 - + - 字体 + + @@ -20265,6 +20331,16 @@ 值1 + + + int值1 + + + + + long值1 + + Tag @@ -20897,6 +20973,52 @@ 热键文本框 + + + 清除按钮位置 + + + + + 热键文本位置 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -24633,6 +24755,11 @@ Chrome风格的多标签控件 + + + 获取或设置调整控件的选项卡大小的方式。 + + @@ -30255,12 +30382,12 @@ - Automatically sets the size of the label by content size + 根据内容大小自动设置标签的大小 - Automatically sets the height of the label by content height (width is not effected). + 根据内容高度自动设置标签的高度(宽度不受影响)。 @@ -54175,7 +54302,7 @@ Bounds of the cell The string to be drawn - 笔刷 + @@ -54198,6 +54325,37 @@ + + + Draw the given text and optional image in the "normal" fashion + + Graphics context to use for drawing + Bounds of the cell + + The string to be drawn + 笔刷 + + + + Draw the given text and optional image in the "normal" fashion + + Graphics context to use for drawing + Bounds of the cell + + The string to be drawn + + + + + + + 这里的r + + + + + + @@ -58222,6 +58380,79 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Wrapper over the control like TextBox. @@ -70094,79 +70325,6 @@ A visual indicator is displayed in the number margin. - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - A class for the Batch lexer. diff --git a/CHANGELOG.md b/CHANGELOG.md index f7d5e4e..6b9e236 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,4 +1,23 @@ -## :date:2025-06-27 星期五更新 +## :date:2025-08-16 星期六更新 + +### rycUpdate V1.0.2506.0401 +- :lady_beetle:[修复]修复文件替换失败,不会失败提示的BUG。 + +### RaUI V4.0.2508.1601 +- :cactus:[新增]ChromeTabControl控件支持设置SizeMode属性。 +- :cactus:[新增]HotkeyTextBox新增支持传入热键文本进行自动转换。 +- :cactus:[新增]ryQuickSQL类新增GetJsonData方法。 +- :cactus:[新增]ryQuickSQL类新增DateToTimeStamp属性,导出时自动将时间类型转为时间戳。 +- :cactus:[新增]自动更新模块新增支持版本类型,区分正式版和测试版。 +- :100:[改进]HotkeyTextBox控件渲染方式改成全画布渲染。 +- :100:[改进]TextBoxEx2开启多行模式后,空文本改成在第一行显示。 +- :lady_beetle:[修复]修复截图功能某些情况下会报错的BUG。 +- :lady_beetle:[修复]修复HotkeyValue类处理多功能键文本时转换错误的BUG。 +- :lady_beetle:[修复]修复RyComboBox控件在某些情况下边框会丢失的BUG。 +- :lady_beetle:[修复]修复Hosts类针对删除hosts规则处理出错的BUG。 +- :lady_beetle:[修复]修复当升级文件Url无法访问时,升级模块会无限期等待的BUG。 + +## :date:2025-06-27 星期五更新 ### RaUI V4.0.2506.2701 - :cactus:[新增]RediskCheck类新增支持对.NET3.5和.NET6-.NET9安装状态的判断。 diff --git a/Source/Itrycn_Project2/Config/Init.cs b/Source/Itrycn_Project2/Config/Init.cs index 9971c34..7ea0e95 100644 --- a/Source/Itrycn_Project2/Config/Init.cs +++ b/Source/Itrycn_Project2/Config/Init.cs @@ -21,6 +21,7 @@ namespace Itrycn_Project2.Config } else { + Public_Config.LoadSetting(); Application.Run(new FrmStart(args)); //Application.Run(new FrmTest2()); //Application.Run(new WindowsFormsApp2.Form1()); diff --git a/Source/Itrycn_Project2/Config/Public_Config.cs b/Source/Itrycn_Project2/Config/Public_Config.cs index 18c128f..7a78f11 100644 --- a/Source/Itrycn_Project2/Config/Public_Config.cs +++ b/Source/Itrycn_Project2/Config/Public_Config.cs @@ -17,7 +17,7 @@ namespace Itrycn_Project2 public static void LoadSetting() { ryCommon.Storage Stor = new ryCommon.Storage(); - Stor.LoadFromFile(Soft_ConstInfo.UserDataFolder+"\\Setting.dat"); + Stor.LoadFromFile(Soft_ConstInfo.UserDataFolder+"\\Setting.xml"); Stor.SelectNodeBySet(); HideByCloseBtn = Stor.GetAttrValue("HideByCloseBtn", false); //low_count = Stor.GetAttrValue("LowCount", 10); diff --git a/Source/Itrycn_Project2/FrmStart.Designer.cs b/Source/Itrycn_Project2/FrmStart.Designer.cs index 19a654c..1a4b5e0 100644 --- a/Source/Itrycn_Project2/FrmStart.Designer.cs +++ b/Source/Itrycn_Project2/FrmStart.Designer.cs @@ -44,19 +44,18 @@ this.捐助ToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); this.chromeTabControl1 = new ryControls.ChromeTabControl(); this.tabPage1 = new System.Windows.Forms.TabPage(); + this.textBoxEx21 = new ryControls.TextBoxEx2(); + this.buttonEx1 = new ryControls.ButtonEx(); + this.hotkeyTextBox1 = new ryControls.HotkeyTextBox(); this.rySearch1 = new ryControls.rySearch(); this.doubleText1 = new ryControls.DoubleText(); this.ryComboBox1 = new ryControls.ComboBoxEx2(); - this.textBoxEx21 = new ryControls.TextBoxEx2(); this.textBoxEx1 = new ryControls.TextBoxEx(); - this.button3 = new System.Windows.Forms.Button(); this.richTextBox21 = new ryControls.Controls.RichTextBox2(); - this.button2 = new System.Windows.Forms.Button(); this.htmlPanel1 = new TheArtOfDev.HtmlRenderer.WinForms.HtmlPanel(); this.pictureBox2 = new System.Windows.Forms.PictureBox(); this.pictureBox1 = new System.Windows.Forms.PictureBox(); this.TabLogs = new System.Windows.Forms.TabPage(); - this.button1 = new System.Windows.Forms.Button(); this.LvLogs = new BrightIdeasSoftware.ObjectListView(); this.OlvLogTime = ((BrightIdeasSoftware.OLVColumn)(new BrightIdeasSoftware.OLVColumn())); this.OlvLogText = ((BrightIdeasSoftware.OLVColumn)(new BrightIdeasSoftware.OLVColumn())); @@ -159,6 +158,7 @@ this.chromeTabControl1.Controls.Add(this.tabPage1); this.chromeTabControl1.Controls.Add(this.TabLogs); this.chromeTabControl1.Cursor = System.Windows.Forms.Cursors.Default; + this.chromeTabControl1.DrawTabBorder = true; this.chromeTabControl1.ItemSize = new System.Drawing.Size(100, 25); this.chromeTabControl1.Location = new System.Drawing.Point(1, 55); this.chromeTabControl1.Name = "chromeTabControl1"; @@ -166,7 +166,6 @@ this.chromeTabControl1.ShowAddButton = false; this.chromeTabControl1.ShowCloseButton = false; this.chromeTabControl1.Size = new System.Drawing.Size(1005, 664); - this.chromeTabControl1.SizeMode = System.Windows.Forms.TabSizeMode.Fixed; this.chromeTabControl1.TabContextMenuStrip = null; this.chromeTabControl1.TabIndex = 0; this.chromeTabControl1.TabMaxWidth = 100; @@ -174,14 +173,14 @@ // tabPage1 // this.tabPage1.AutoScroll = true; + this.tabPage1.Controls.Add(this.textBoxEx21); + this.tabPage1.Controls.Add(this.buttonEx1); + this.tabPage1.Controls.Add(this.hotkeyTextBox1); this.tabPage1.Controls.Add(this.rySearch1); this.tabPage1.Controls.Add(this.doubleText1); this.tabPage1.Controls.Add(this.ryComboBox1); - this.tabPage1.Controls.Add(this.textBoxEx21); this.tabPage1.Controls.Add(this.textBoxEx1); - this.tabPage1.Controls.Add(this.button3); this.tabPage1.Controls.Add(this.richTextBox21); - this.tabPage1.Controls.Add(this.button2); this.tabPage1.Controls.Add(this.htmlPanel1); this.tabPage1.Controls.Add(this.pictureBox2); this.tabPage1.Controls.Add(this.pictureBox1); @@ -193,6 +192,52 @@ this.tabPage1.Text = "首页"; this.tabPage1.UseVisualStyleBackColor = true; // + // textBoxEx21 + // + this.textBoxEx21.BackColor = System.Drawing.Color.White; + this.textBoxEx21.EmptyText = "fggzgftgg "; + this.textBoxEx21.Location = new System.Drawing.Point(161, 30); + this.textBoxEx21.LongTime = 2000; + this.textBoxEx21.MaxLength = 999999999; + this.textBoxEx21.MaxUndoRedoSteps = 50; + this.textBoxEx21.Multiline = true; + this.textBoxEx21.Name = "textBoxEx21"; + this.textBoxEx21.OnlyNumeric = false; + this.textBoxEx21.PasswordChar = '\0'; + this.textBoxEx21.ReadOnly = false; + this.textBoxEx21.SelectedText = ""; + this.textBoxEx21.SelectionLength = 0; + this.textBoxEx21.SelectionStart = 0; + this.textBoxEx21.Size = new System.Drawing.Size(339, 179); + this.textBoxEx21.TabIndex = 31; + this.textBoxEx21.TextAlign = System.Windows.Forms.HorizontalAlignment.Left; + this.textBoxEx21.ToolTip = ""; + this.textBoxEx21.WordWrap = true; + // + // buttonEx1 + // + this.buttonEx1.BackColor = System.Drawing.Color.Gray; + this.buttonEx1.BaseColor = System.Drawing.Color.FromArgb(((int)(((byte)(51)))), ((int)(((byte)(76)))), ((int)(((byte)(95))))); + this.buttonEx1.ImageTextSpace = 0; + this.buttonEx1.ImageWidth = 12; + this.buttonEx1.Location = new System.Drawing.Point(180, 153); + this.buttonEx1.Name = "buttonEx1"; + this.buttonEx1.Size = new System.Drawing.Size(61, 27); + this.buttonEx1.TabIndex = 30; + this.buttonEx1.Text = "测试"; + this.buttonEx1.UseVisualStyleBackColor = false; + // + // hotkeyTextBox1 + // + this.hotkeyTextBox1.BackColor = System.Drawing.Color.White; + this.hotkeyTextBox1.HotKey = "0+0"; + this.hotkeyTextBox1.Location = new System.Drawing.Point(161, 215); + this.hotkeyTextBox1.Name = "hotkeyTextBox1"; + this.hotkeyTextBox1.Size = new System.Drawing.Size(220, 27); + this.hotkeyTextBox1.T_Key = System.Windows.Forms.Keys.None; + this.hotkeyTextBox1.T_Modifiers = 0; + this.hotkeyTextBox1.TabIndex = 29; + // // rySearch1 // this.rySearch1.BackColor = System.Drawing.Color.FromArgb(((int)(((byte)(236)))), ((int)(((byte)(239)))), ((int)(((byte)(244))))); @@ -209,7 +254,7 @@ this.doubleText1.Location = new System.Drawing.Point(141, 265); this.doubleText1.Name = "doubleText1"; this.doubleText1.SelectName = ""; - this.doubleText1.Size = new System.Drawing.Size(240, 39); + this.doubleText1.Size = new System.Drawing.Size(240, 27); this.doubleText1.TabIndex = 26; // // ryComboBox1 @@ -225,33 +270,11 @@ this.ryComboBox1.MaxPopupHeight = 0; this.ryComboBox1.MaxPopupWidth = 0; this.ryComboBox1.Name = "ryComboBox1"; + this.ryComboBox1.SelectedIndex = -1; + this.ryComboBox1.SelectedItem = null; this.ryComboBox1.Size = new System.Drawing.Size(238, 36); this.ryComboBox1.TabIndex = 25; - // - // textBoxEx21 - // - this.textBoxEx21.BackColor = System.Drawing.Color.White; - this.textBoxEx21.EmptyText = "ddd对对对"; - this.textBoxEx21.Location = new System.Drawing.Point(149, 170); - this.textBoxEx21.LongTime = 2000; - this.textBoxEx21.MaxLength = 999999999; - this.textBoxEx21.MaxUndoRedoSteps = 50; - this.textBoxEx21.Multiline = false; - this.textBoxEx21.Name = "textBoxEx21"; - this.textBoxEx21.OnlyNumeric = false; - this.textBoxEx21.PasswordChar = '\0'; - this.textBoxEx21.ReadOnly = false; - this.textBoxEx21.SelectedText = ""; - this.textBoxEx21.SelectionLength = 0; - this.textBoxEx21.SelectionStart = 0; - this.textBoxEx21.Size = new System.Drawing.Size(233, 33); - this.textBoxEx21.TabIndex = 24; - this.textBoxEx21.Text = "textBoxEx21"; - this.textBoxEx21.TextAlign = System.Windows.Forms.HorizontalAlignment.Left; - this.textBoxEx21.ToolTip = ""; - this.textBoxEx21.WordWrap = true; - this.textBoxEx21.LongTimeNoChanged += new System.EventHandler(this.textBoxEx21_LongTimeNoChanged); - this.textBoxEx21.KeyDown += new System.Windows.Forms.KeyEventHandler(this.textBoxEx21_KeyDown); + this.ryComboBox1.ToolTipText = ""; // // textBoxEx1 // @@ -264,19 +287,8 @@ this.textBoxEx1.Size = new System.Drawing.Size(202, 21); this.textBoxEx1.TabIndex = 23; // - // button3 - // - this.button3.Location = new System.Drawing.Point(254, 105); - this.button3.Name = "button3"; - this.button3.Size = new System.Drawing.Size(143, 37); - this.button3.TabIndex = 22; - this.button3.Text = "button3"; - this.button3.UseVisualStyleBackColor = true; - this.button3.Click += new System.EventHandler(this.button3_Click); - // // richTextBox21 // - this.richTextBox21.DetectUrls = false; this.richTextBox21.EmptyText = ""; this.richTextBox21.Font = new System.Drawing.Font("Courier New", 10F); this.richTextBox21.Location = new System.Drawing.Point(417, 26); @@ -288,18 +300,6 @@ "赢得道具和奖励,培养她的感情,解锁不同的结局。这款游戏将带给你与怪兽公主共度时光的乐趣与刺激。"; this.richTextBox21.WordWrap = true; // - // button2 - // - this.button2.Location = new System.Drawing.Point(854, 46); - this.button2.MaximumSize = new System.Drawing.Size(143, 37); - this.button2.MinimumSize = new System.Drawing.Size(143, 37); - this.button2.Name = "button2"; - this.button2.Size = new System.Drawing.Size(143, 37); - this.button2.TabIndex = 20; - this.button2.Text = "button2"; - this.button2.UseVisualStyleBackColor = true; - this.button2.Click += new System.EventHandler(this.button2_Click); - // // htmlPanel1 // this.htmlPanel1.AutoScroll = true; @@ -331,7 +331,6 @@ // // TabLogs // - this.TabLogs.Controls.Add(this.button1); this.TabLogs.Controls.Add(this.LvLogs); this.TabLogs.Location = new System.Drawing.Point(1, 29); this.TabLogs.Name = "TabLogs"; @@ -341,16 +340,6 @@ this.TabLogs.Text = "日志"; this.TabLogs.UseVisualStyleBackColor = true; // - // button1 - // - this.button1.Location = new System.Drawing.Point(275, 64); - this.button1.Name = "button1"; - this.button1.Size = new System.Drawing.Size(125, 29); - this.button1.TabIndex = 15; - this.button1.Text = "button1"; - this.button1.UseVisualStyleBackColor = true; - this.button1.Click += new System.EventHandler(this.Button1_Click); - // // LvLogs // this.LvLogs.AllColumns.Add(this.OlvLogTime); @@ -431,17 +420,16 @@ private BrightIdeasSoftware.ObjectListView LvLogs; private BrightIdeasSoftware.OLVColumn OlvLogTime; private BrightIdeasSoftware.OLVColumn OlvLogText; - private System.Windows.Forms.Button button1; private System.Windows.Forms.PictureBox pictureBox1; private System.Windows.Forms.PictureBox pictureBox2; private TheArtOfDev.HtmlRenderer.WinForms.HtmlPanel htmlPanel1; private ryControls.Controls.RichTextBox2 richTextBox21; - private System.Windows.Forms.Button button3; private ryControls.TextBoxEx textBoxEx1; - private ryControls.TextBoxEx2 textBoxEx21; private ryControls.ComboBoxEx2 ryComboBox1; - private System.Windows.Forms.Button button2; private ryControls.DoubleText doubleText1; private ryControls.rySearch rySearch1; + private ryControls.HotkeyTextBox hotkeyTextBox1; + private ryControls.ButtonEx buttonEx1; + private ryControls.TextBoxEx2 textBoxEx21; } } \ No newline at end of file diff --git a/Source/Itrycn_Project2/FrmStart.cs b/Source/Itrycn_Project2/FrmStart.cs index 0903594..8481d2e 100644 --- a/Source/Itrycn_Project2/FrmStart.cs +++ b/Source/Itrycn_Project2/FrmStart.cs @@ -16,7 +16,6 @@ using System.Linq; using System.Text; using System.Threading; using System.Windows.Forms; -using static System.Net.Mime.MediaTypeNames; using static System.Windows.Forms.VisualStyles.VisualStyleElement; namespace Itrycn_Project2 @@ -161,6 +160,7 @@ namespace Itrycn_Project2 } LvLogs.InsertObjects(0, new LogInfo[] { new LogInfo() { LogTime = DateTime.Now, LogText = log,LogTag=tag, Color = color } }); OlvLogTime.Text = "时间(" + LvLogs.GetItemCount() + ")"; + TabLogs.Text = "日志(" + LvLogs.GetItemCount() + ")"; ; })); } catch { } @@ -265,11 +265,13 @@ namespace Itrycn_Project2 private void FrmStart_Load(object sender, EventArgs e) { - ryComboBox1.SelectedIndex=0; + //SaveBase64ImageAsFile("", Application.StartupPath + "\\1111.jpg"); + //hotkeyTextBox1.LoadHotKey("Ctrl+Shift+A"); + //ryComboBox1.SelectedIndex=0; //var process = Process.GetProcessesByName("bds"); //System.Net.ServicePointManager.DefaultConnectionLimit = 50; - QuickWeb web = new QuickWeb(); - var http = web.UrlEncode("猫咪——安安"); + //QuickWeb web = new QuickWeb(); + //var http = web.UrlEncode("猫咪——安安"); //web.Referer = "http://k73dx12.tengapk.com/android/dreamhouse.mod.apk"; //var kk = web.GetSize("http://42.248.92.71:2080/k73dx12.tengapk.com/android/dreamhouse.mod.apk?wsiphost=ipdbme&wsrid_tag=66b17fe7_PS-HYN-01IIQ27_63791-5797-s1t1722908647649&ip_type=0"); //IDbInterface db = new MySqlDataProvider(); @@ -278,13 +280,13 @@ namespace Itrycn_Project2 //var size= web.GetSize("https://oss-admin.blazingcats.com/Product/Package/100_llfz_101_llfzgw_1656930048.apk"); //size = web.GetSize("https://oss-admin.blazingcats.com/Product/Package/100_llfz_101_llfzgw_1656930048.apk"); //textBox2.Text = web.Get("https://apkpure.com/cn/animation-throwdown-epic-ccg/com.kongregate.mobile.throwdown.google/download").Html; - ryCommon.ApkOp apkOp = new ApkOp(); - apkOp.AAPT_Path = "E:\\My Datas\\My Codes\\毕方项目\\CSharp\\ryProcessManager\\Bin\\Debug\\SysDb\\Tools\\ApkLook\\aapt.exe"; - var kk = apkOp.Read_Apk("C:\\Users\\zilin\\Desktop\\Measure X.apk"); + //ryCommon.ApkOp apkOp = new ApkOp(); + //apkOp.AAPT_Path = "E:\\My Datas\\My Codes\\毕方项目\\CSharp\\ryProcessManager\\Bin\\Debug\\SysDb\\Tools\\ApkLook\\aapt.exe"; + //var kk = apkOp.Read_Apk("C:\\Users\\zilin\\Desktop\\com.lhdn.apk"); // objectListView1.InsertObjects(0, new LogInfo[] { new LogInfo() }); //var en= ryCommon.TxtFileEncoder.GetEncoding(@"E:\My Datas\毕方项目\CSharp\ryProcessManager\Bin\Debug\SysDb\applist.lst"); - //var hosts = ryCommon.RyFiles.ReadAllText(@"E:\My Datas\毕方项目\CSharp\ryProcessManager\Bin\Debug\UserDb\Hosts.txt"); - //var result = ryCommon.Hosts.AddHosts(hosts); + var hosts = ryCommon.RyFiles.ReadAllText(@"E:\My Datas\My Codes\毕方项目\CSharp\ryProcessManager\Bin\Debug\UserDb\Hosts.txt"); + var result = ryCommon.Hosts.AddHosts(hosts); //var kk= ryCommon.ProcessExt.GetPath(24348); //var img = RyImage.LoadPic(@"C:\Users\zilin\Desktop\1.jpg"); //var watermark =new Bitmap(RyImage.LoadPic(@"C:\Users\zilin\Desktop\water.png")); @@ -356,78 +358,5 @@ namespace Itrycn_Project2 /// public Color Color { get; set; } = Color.Black; } - - private void Button1_Click(object sender, EventArgs e) - { - LvLogs.ClearObjects(); - AddLog("测试测试"); - } - - private void textBox1_TextChanged(object sender, EventArgs e) - { - //var text = ""; - //try - //{ - // HtmlAgilityPack.HtmlDocument htmlDoc = new HtmlAgilityPack.HtmlDocument(); - // htmlDoc.LoadHtml(textBox2.Text); - // HtmlNodeCollection anchors = htmlDoc.DocumentNode.SelectNodes(textBox1.Text); - // if (anchors != null) - // { - // for (int i = 0; i < anchors.Count; i++) - // { - // if (text != "") { text += "

"; } - // if (i % 2 == 0) - // { - // text += "" + System.Web.HttpUtility.HtmlEncode(anchors[i].OuterHtml) + ""; - // } - // else - // { - // text += "" + System.Web.HttpUtility.HtmlEncode(anchors[i].OuterHtml) + ""; - // } - // } - // } - //} - //catch (Exception ex){ - // text = "" + System.Web.HttpUtility.HtmlEncode(ex.Message) + ""; - //} - //htmlPanel1.Text = System.Web.HttpUtility.HtmlEncode(textBox1.Text); - } - ILayeredForm subForm = null; - private void button2_Click(object sender, EventArgs e) - { - subForm = new FormTest(); - subForm.Layered(button2); - subForm.Disposed += (a, b) => - { - subForm = null; - }; - subForm.Show(); - } - - private void button3_Click(object sender, EventArgs e) - { - Form form=(Form)Activator.CreateInstance(typeof(FrmTest2)); ; - ShowInCenter(form, this); - ryCommon.RyForm.BringToTop(form.Handle); - ryCommon.RyForm.SetActiveWindow(form.Handle); - try - { - if (!form.IsDisposed) form.Show(); - } - catch { } - } - - private void textBoxEx21_KeyDown(object sender, KeyEventArgs e) - { - if (e.KeyCode == Keys.Enter) - { - MessageBox.Show("111"); - } - } - - private void textBoxEx21_LongTimeNoChanged(object sender, EventArgs e) - { - MessageBox.Show("222"); - } } } diff --git a/Source/Itrycn_Project2/FrmStart.resx b/Source/Itrycn_Project2/FrmStart.resx index 4beb845..98fac57 100644 --- a/Source/Itrycn_Project2/FrmStart.resx +++ b/Source/Itrycn_Project2/FrmStart.resx @@ -126,62 +126,8 @@ 246, 17 - - True - - - True - - - True - - - True - - - True - - - True - - - True - - - True - - - True - - - True - - - True - - - True - - - True - - - True - - - True - - - True - - - True - - - True - - 54 + 25 diff --git a/Source/OnLineUpgradeConfig/frmUpdateFile.Designer.cs b/Source/OnLineUpgradeConfig/frmUpdateFile.Designer.cs index 4966916..7c8ffdc 100644 --- a/Source/OnLineUpgradeConfig/frmUpdateFile.Designer.cs +++ b/Source/OnLineUpgradeConfig/frmUpdateFile.Designer.cs @@ -35,7 +35,7 @@ namespace LiveUpdate this.BtnOK = new System.Windows.Forms.Button(); this.tabControl1 = new System.Windows.Forms.TabControl(); this.tabPage1 = new System.Windows.Forms.TabPage(); - this.cmbNewVer = new ryControls.TextBoxEx2(); + this.label10 = new System.Windows.Forms.Label(); this.checkBox2 = new System.Windows.Forms.CheckBox(); this.checkBox1 = new System.Windows.Forms.CheckBox(); this.linkLabel8 = new System.Windows.Forms.LinkLabel(); @@ -49,37 +49,27 @@ namespace LiveUpdate this.linkLabel1 = new System.Windows.Forms.LinkLabel(); this.label12 = new System.Windows.Forms.Label(); this.BtnOneKeyUpdate = new System.Windows.Forms.Button(); - this.txtDbUpdateDes = new ryControls.TextBoxEx2(); - this.txtUpdateDes = new ryControls.TextBoxEx2(); this.label8 = new System.Windows.Forms.Label(); this.label7 = new System.Windows.Forms.Label(); - this.cmbDbUpdateUrl = new ryControls.RyComboBox(); this.label6 = new System.Windows.Forms.Label(); - this.cmbProcUpdateUrl = new ryControls.RyComboBox(); this.label5 = new System.Windows.Forms.Label(); this.dtNewDataDate = new System.Windows.Forms.DateTimePicker(); this.label4 = new System.Windows.Forms.Label(); this.dtNewProcDate = new System.Windows.Forms.DateTimePicker(); this.label3 = new System.Windows.Forms.Label(); - this.cmbNewDbVer = new ryControls.RyComboBox(); this.label2 = new System.Windows.Forms.Label(); this.label1 = new System.Windows.Forms.Label(); this.tabPage2 = new System.Windows.Forms.TabPage(); - this.txtDelFileList = new ryControls.Controls.RichTextBox2(); - this.txtKillProcList = new ryControls.Controls.RichTextBox2(); this.btnSelectUser = new System.Windows.Forms.Button(); this.label16 = new System.Windows.Forms.Label(); this.label15 = new System.Windows.Forms.Label(); this.label14 = new System.Windows.Forms.Label(); this.label11 = new System.Windows.Forms.Label(); this.label9 = new System.Windows.Forms.Label(); - this.txtMainProcPram = new ryControls.TextBoxEx2(); - this.txtMainProcName = new ryControls.TextBoxEx2(); - this.txtUserList = new ryControls.RyComboBox(); this.tabPage3 = new System.Windows.Forms.TabPage(); + this.BtnDefUpdateLog = new System.Windows.Forms.Button(); this.BtnPasteFromMD = new System.Windows.Forms.Button(); this.ChkUseHtml = new System.Windows.Forms.CheckBox(); - this.TxtUpdateDes_Html = new ryControls.Controls.RichTextBox2(); this.tabPage4 = new System.Windows.Forms.TabPage(); this.LblState = new System.Windows.Forms.Label(); this.BtnCopyToNormal = new System.Windows.Forms.Button(); @@ -89,6 +79,19 @@ namespace LiveUpdate this.BtnUsersView = new System.Windows.Forms.Button(); this.LvUpdateFiles = new BrightIdeasSoftware.ObjectListView(); this.OlvFileName = ((BrightIdeasSoftware.OLVColumn)(new BrightIdeasSoftware.OLVColumn())); + this.CbbVersionType = new ryControls.RyComboBox(); + this.cmbNewVer = new ryControls.TextBoxEx2(); + this.txtDbUpdateDes = new ryControls.TextBoxEx2(); + this.txtUpdateDes = new ryControls.TextBoxEx2(); + this.cmbDbUpdateUrl = new ryControls.RyComboBox(); + this.cmbProcUpdateUrl = new ryControls.RyComboBox(); + this.cmbNewDbVer = new ryControls.RyComboBox(); + this.txtDelFileList = new ryControls.Controls.RichTextBox2(); + this.txtKillProcList = new ryControls.Controls.RichTextBox2(); + this.txtMainProcPram = new ryControls.TextBoxEx2(); + this.txtMainProcName = new ryControls.TextBoxEx2(); + this.txtUserList = new ryControls.RyComboBox(); + this.TxtUpdateDes_Html = new ryControls.Controls.RichTextBox2(); this.tabControl1.SuspendLayout(); this.tabPage1.SuspendLayout(); this.tabPage2.SuspendLayout(); @@ -137,6 +140,8 @@ namespace LiveUpdate // tabPage1 // this.tabPage1.BackColor = System.Drawing.Color.White; + this.tabPage1.Controls.Add(this.CbbVersionType); + this.tabPage1.Controls.Add(this.label10); this.tabPage1.Controls.Add(this.cmbNewVer); this.tabPage1.Controls.Add(this.checkBox2); this.tabPage1.Controls.Add(this.checkBox1); @@ -173,29 +178,14 @@ namespace LiveUpdate this.tabPage1.TabIndex = 0; this.tabPage1.Text = "基本设置"; // - // cmbNewVer + // label10 // - this.cmbNewVer.BackColor = System.Drawing.Color.White; - this.cmbNewVer.EmptyText = ""; - this.cmbNewVer.Font = new System.Drawing.Font("宋体", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134))); - this.cmbNewVer.Location = new System.Drawing.Point(9, 23); - this.cmbNewVer.LongTime = 2000; - this.cmbNewVer.Margin = new System.Windows.Forms.Padding(4, 4, 4, 4); - this.cmbNewVer.MaxLength = 999999999; - this.cmbNewVer.MaxUndoRedoSteps = 50; - this.cmbNewVer.Multiline = false; - this.cmbNewVer.Name = "cmbNewVer"; - this.cmbNewVer.OnlyNumeric = false; - this.cmbNewVer.PasswordChar = '\0'; - this.cmbNewVer.ReadOnly = false; - this.cmbNewVer.SelectedText = ""; - this.cmbNewVer.SelectionLength = 0; - this.cmbNewVer.SelectionStart = 0; - this.cmbNewVer.Size = new System.Drawing.Size(223, 31); - this.cmbNewVer.TabIndex = 47; - this.cmbNewVer.TextAlign = System.Windows.Forms.HorizontalAlignment.Left; - this.cmbNewVer.ToolTip = ""; - this.cmbNewVer.WordWrap = true; + this.label10.AutoSize = true; + this.label10.Location = new System.Drawing.Point(317, 8); + this.label10.Name = "label10"; + this.label10.Size = new System.Drawing.Size(53, 12); + this.label10.TabIndex = 48; + this.label10.Text = "版本类型"; // // checkBox2 // @@ -353,56 +343,6 @@ namespace LiveUpdate this.BtnOneKeyUpdate.UseVisualStyleBackColor = true; this.BtnOneKeyUpdate.Click += new System.EventHandler(this.BtnOneKeyUpdate_Click); // - // txtDbUpdateDes - // - this.txtDbUpdateDes.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left) - | System.Windows.Forms.AnchorStyles.Right))); - this.txtDbUpdateDes.BackColor = System.Drawing.Color.White; - this.txtDbUpdateDes.EmptyText = ""; - this.txtDbUpdateDes.Enabled = false; - this.txtDbUpdateDes.Location = new System.Drawing.Point(10, 380); - this.txtDbUpdateDes.LongTime = 2000; - this.txtDbUpdateDes.MaxLength = 999999999; - this.txtDbUpdateDes.MaxUndoRedoSteps = 50; - this.txtDbUpdateDes.Multiline = true; - this.txtDbUpdateDes.Name = "txtDbUpdateDes"; - this.txtDbUpdateDes.OnlyNumeric = false; - this.txtDbUpdateDes.PasswordChar = '\0'; - this.txtDbUpdateDes.ReadOnly = false; - this.txtDbUpdateDes.SelectedText = ""; - this.txtDbUpdateDes.SelectionLength = 0; - this.txtDbUpdateDes.SelectionStart = 0; - this.txtDbUpdateDes.Size = new System.Drawing.Size(657, 133); - this.txtDbUpdateDes.TabIndex = 31; - this.txtDbUpdateDes.TextAlign = System.Windows.Forms.HorizontalAlignment.Left; - this.txtDbUpdateDes.ToolTip = ""; - this.txtDbUpdateDes.WordWrap = true; - // - // txtUpdateDes - // - this.txtUpdateDes.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom) - | System.Windows.Forms.AnchorStyles.Left) - | System.Windows.Forms.AnchorStyles.Right))); - this.txtUpdateDes.BackColor = System.Drawing.Color.White; - this.txtUpdateDes.EmptyText = ""; - this.txtUpdateDes.Location = new System.Drawing.Point(10, 195); - this.txtUpdateDes.LongTime = 2000; - this.txtUpdateDes.MaxLength = 999999999; - this.txtUpdateDes.MaxUndoRedoSteps = 50; - this.txtUpdateDes.Multiline = true; - this.txtUpdateDes.Name = "txtUpdateDes"; - this.txtUpdateDes.OnlyNumeric = false; - this.txtUpdateDes.PasswordChar = '\0'; - this.txtUpdateDes.ReadOnly = false; - this.txtUpdateDes.SelectedText = ""; - this.txtUpdateDes.SelectionLength = 0; - this.txtUpdateDes.SelectionStart = 0; - this.txtUpdateDes.Size = new System.Drawing.Size(657, 164); - this.txtUpdateDes.TabIndex = 30; - this.txtUpdateDes.TextAlign = System.Windows.Forms.HorizontalAlignment.Left; - this.txtUpdateDes.ToolTip = ""; - this.txtUpdateDes.WordWrap = true; - // // label8 // this.label8.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left))); @@ -422,20 +362,6 @@ namespace LiveUpdate this.label7.TabIndex = 28; this.label7.Text = "软件更新描述:"; // - // cmbDbUpdateUrl - // - this.cmbDbUpdateUrl.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left) - | System.Windows.Forms.AnchorStyles.Right))); - this.cmbDbUpdateUrl.DrawMode = System.Windows.Forms.DrawMode.OwnerDrawFixed; - this.cmbDbUpdateUrl.Enabled = false; - this.cmbDbUpdateUrl.FlatStyle = System.Windows.Forms.FlatStyle.Flat; - this.cmbDbUpdateUrl.FormattingEnabled = true; - this.cmbDbUpdateUrl.Location = new System.Drawing.Point(9, 155); - this.cmbDbUpdateUrl.MaxUndoRedoSteps = 50; - this.cmbDbUpdateUrl.Name = "cmbDbUpdateUrl"; - this.cmbDbUpdateUrl.Size = new System.Drawing.Size(658, 22); - this.cmbDbUpdateUrl.TabIndex = 27; - // // label6 // this.label6.AutoSize = true; @@ -445,19 +371,6 @@ namespace LiveUpdate this.label6.TabIndex = 26; this.label6.Text = "数据库更新地址:"; // - // cmbProcUpdateUrl - // - this.cmbProcUpdateUrl.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left) - | System.Windows.Forms.AnchorStyles.Right))); - this.cmbProcUpdateUrl.DrawMode = System.Windows.Forms.DrawMode.OwnerDrawFixed; - this.cmbProcUpdateUrl.FlatStyle = System.Windows.Forms.FlatStyle.Flat; - this.cmbProcUpdateUrl.FormattingEnabled = true; - this.cmbProcUpdateUrl.Location = new System.Drawing.Point(9, 117); - this.cmbProcUpdateUrl.MaxUndoRedoSteps = 50; - this.cmbProcUpdateUrl.Name = "cmbProcUpdateUrl"; - this.cmbProcUpdateUrl.Size = new System.Drawing.Size(658, 22); - this.cmbProcUpdateUrl.TabIndex = 25; - // // label5 // this.label5.AutoSize = true; @@ -473,7 +386,7 @@ namespace LiveUpdate this.dtNewDataDate.Enabled = false; this.dtNewDataDate.Font = new System.Drawing.Font("宋体", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134))); this.dtNewDataDate.Format = System.Windows.Forms.DateTimePickerFormat.Custom; - this.dtNewDataDate.Location = new System.Drawing.Point(326, 72); + this.dtNewDataDate.Location = new System.Drawing.Point(447, 71); this.dtNewDataDate.Name = "dtNewDataDate"; this.dtNewDataDate.Size = new System.Drawing.Size(201, 26); this.dtNewDataDate.TabIndex = 23; @@ -481,7 +394,7 @@ namespace LiveUpdate // label4 // this.label4.AutoSize = true; - this.label4.Location = new System.Drawing.Point(324, 57); + this.label4.Location = new System.Drawing.Point(445, 56); this.label4.Name = "label4"; this.label4.Size = new System.Drawing.Size(95, 12); this.label4.TabIndex = 22; @@ -509,23 +422,10 @@ namespace LiveUpdate this.label3.TabIndex = 20; this.label3.Text = "最新软件日期:"; // - // cmbNewDbVer - // - this.cmbNewDbVer.DrawMode = System.Windows.Forms.DrawMode.OwnerDrawFixed; - this.cmbNewDbVer.Enabled = false; - this.cmbNewDbVer.FlatStyle = System.Windows.Forms.FlatStyle.Flat; - this.cmbNewDbVer.Font = new System.Drawing.Font("宋体", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134))); - this.cmbNewDbVer.FormattingEnabled = true; - this.cmbNewDbVer.Location = new System.Drawing.Point(326, 25); - this.cmbNewDbVer.MaxUndoRedoSteps = 50; - this.cmbNewDbVer.Name = "cmbNewDbVer"; - this.cmbNewDbVer.Size = new System.Drawing.Size(122, 27); - this.cmbNewDbVer.TabIndex = 19; - // // label2 // this.label2.AutoSize = true; - this.label2.Location = new System.Drawing.Point(324, 8); + this.label2.Location = new System.Drawing.Point(445, 7); this.label2.Name = "label2"; this.label2.Size = new System.Drawing.Size(95, 12); this.label2.TabIndex = 18; @@ -563,35 +463,6 @@ namespace LiveUpdate this.tabPage2.TabIndex = 1; this.tabPage2.Text = "升级前后"; // - // txtDelFileList - // - this.txtDelFileList.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom) - | System.Windows.Forms.AnchorStyles.Left) - | System.Windows.Forms.AnchorStyles.Right))); - this.txtDelFileList.EmptyText = ""; - this.txtDelFileList.Font = new System.Drawing.Font("Courier New", 10F); - this.txtDelFileList.Location = new System.Drawing.Point(10, 198); - this.txtDelFileList.Name = "txtDelFileList"; - this.txtDelFileList.OnlyInputText = false; - this.txtDelFileList.Size = new System.Drawing.Size(660, 233); - this.txtDelFileList.TabIndex = 37; - this.txtDelFileList.Text = ""; - this.txtDelFileList.WordWrap = true; - // - // txtKillProcList - // - this.txtKillProcList.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left) - | System.Windows.Forms.AnchorStyles.Right))); - this.txtKillProcList.EmptyText = ""; - this.txtKillProcList.Font = new System.Drawing.Font("Courier New", 10F); - this.txtKillProcList.Location = new System.Drawing.Point(10, 22); - this.txtKillProcList.Name = "txtKillProcList"; - this.txtKillProcList.OnlyInputText = false; - this.txtKillProcList.Size = new System.Drawing.Size(660, 158); - this.txtKillProcList.TabIndex = 36; - this.txtKillProcList.Text = ""; - this.txtKillProcList.WordWrap = true; - // // btnSelectUser // this.btnSelectUser.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right))); @@ -651,73 +522,13 @@ namespace LiveUpdate this.label9.AutoSize = true; this.label9.Location = new System.Drawing.Point(8, 7); this.label9.Name = "label9"; - this.label9.Size = new System.Drawing.Size(149, 12); + this.label9.Size = new System.Drawing.Size(467, 12); this.label9.TabIndex = 0; - this.label9.Text = "升级前需要结束的进程列表"; - // - // txtMainProcPram - // - this.txtMainProcPram.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right))); - this.txtMainProcPram.BackColor = System.Drawing.Color.White; - this.txtMainProcPram.EmptyText = ""; - this.txtMainProcPram.Location = new System.Drawing.Point(577, 450); - this.txtMainProcPram.LongTime = 2000; - this.txtMainProcPram.MaxLength = 999999999; - this.txtMainProcPram.MaxUndoRedoSteps = 50; - this.txtMainProcPram.Multiline = false; - this.txtMainProcPram.Name = "txtMainProcPram"; - this.txtMainProcPram.OnlyNumeric = false; - this.txtMainProcPram.PasswordChar = '\0'; - this.txtMainProcPram.ReadOnly = false; - this.txtMainProcPram.SelectedText = ""; - this.txtMainProcPram.SelectionLength = 0; - this.txtMainProcPram.SelectionStart = 0; - this.txtMainProcPram.Size = new System.Drawing.Size(92, 21); - this.txtMainProcPram.TabIndex = 9; - this.txtMainProcPram.TextAlign = System.Windows.Forms.HorizontalAlignment.Left; - this.txtMainProcPram.ToolTip = ""; - this.txtMainProcPram.WordWrap = true; - // - // txtMainProcName - // - this.txtMainProcName.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left) - | System.Windows.Forms.AnchorStyles.Right))); - this.txtMainProcName.BackColor = System.Drawing.Color.White; - this.txtMainProcName.EmptyText = ""; - this.txtMainProcName.Location = new System.Drawing.Point(10, 450); - this.txtMainProcName.LongTime = 2000; - this.txtMainProcName.MaxLength = 999999999; - this.txtMainProcName.MaxUndoRedoSteps = 50; - this.txtMainProcName.Multiline = false; - this.txtMainProcName.Name = "txtMainProcName"; - this.txtMainProcName.OnlyNumeric = false; - this.txtMainProcName.PasswordChar = '\0'; - this.txtMainProcName.ReadOnly = false; - this.txtMainProcName.SelectedText = ""; - this.txtMainProcName.SelectionLength = 0; - this.txtMainProcName.SelectionStart = 0; - this.txtMainProcName.Size = new System.Drawing.Size(561, 21); - this.txtMainProcName.TabIndex = 3; - this.txtMainProcName.TextAlign = System.Windows.Forms.HorizontalAlignment.Left; - this.txtMainProcName.ToolTip = ""; - this.txtMainProcName.WordWrap = true; - // - // txtUserList - // - this.txtUserList.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left) - | System.Windows.Forms.AnchorStyles.Right))); - this.txtUserList.DrawMode = System.Windows.Forms.DrawMode.OwnerDrawFixed; - this.txtUserList.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList; - this.txtUserList.Font = new System.Drawing.Font("宋体", 10.5F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134))); - this.txtUserList.FormattingEnabled = true; - this.txtUserList.Location = new System.Drawing.Point(9, 489); - this.txtUserList.MaxUndoRedoSteps = 50; - this.txtUserList.Name = "txtUserList"; - this.txtUserList.Size = new System.Drawing.Size(599, 24); - this.txtUserList.TabIndex = 10; + this.label9.Text = "升级前需要结束的进程列表(默认情况下,填不填写都会结束升级程序所在目录下的进程)"; // // tabPage3 // + this.tabPage3.Controls.Add(this.BtnDefUpdateLog); this.tabPage3.Controls.Add(this.BtnPasteFromMD); this.tabPage3.Controls.Add(this.ChkUseHtml); this.tabPage3.Controls.Add(this.TxtUpdateDes_Html); @@ -729,6 +540,17 @@ namespace LiveUpdate this.tabPage3.Text = "更新日志源码"; this.tabPage3.UseVisualStyleBackColor = true; // + // BtnDefUpdateLog + // + this.BtnDefUpdateLog.Location = new System.Drawing.Point(217, 3); + this.BtnDefUpdateLog.Name = "BtnDefUpdateLog"; + this.BtnDefUpdateLog.Size = new System.Drawing.Size(76, 30); + this.BtnDefUpdateLog.TabIndex = 36; + this.BtnDefUpdateLog.Text = "默认日志"; + this.toolTip1.SetToolTip(this.BtnDefUpdateLog, "只更新版本号和日期"); + this.BtnDefUpdateLog.UseVisualStyleBackColor = true; + this.BtnDefUpdateLog.Click += new System.EventHandler(this.BtnDefUpdateLog_Click); + // // BtnPasteFromMD // this.BtnPasteFromMD.Location = new System.Drawing.Point(135, 3); @@ -750,21 +572,6 @@ namespace LiveUpdate this.ChkUseHtml.Text = "采用Html更新日志"; this.ChkUseHtml.UseVisualStyleBackColor = true; // - // TxtUpdateDes_Html - // - this.TxtUpdateDes_Html.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom) - | System.Windows.Forms.AnchorStyles.Left) - | System.Windows.Forms.AnchorStyles.Right))); - this.TxtUpdateDes_Html.EmptyText = ""; - this.TxtUpdateDes_Html.Font = new System.Drawing.Font("Courier New", 10F); - this.TxtUpdateDes_Html.Location = new System.Drawing.Point(9, 35); - this.TxtUpdateDes_Html.Name = "TxtUpdateDes_Html"; - this.TxtUpdateDes_Html.OnlyInputText = false; - this.TxtUpdateDes_Html.Size = new System.Drawing.Size(660, 481); - this.TxtUpdateDes_Html.TabIndex = 33; - this.TxtUpdateDes_Html.Text = ""; - this.TxtUpdateDes_Html.WordWrap = true; - // // tabPage4 // this.tabPage4.Controls.Add(this.LblState); @@ -862,6 +669,243 @@ namespace LiveUpdate this.OlvFileName.Text = "文件名"; this.OlvFileName.Width = 150; // + // CbbVersionType + // + this.CbbVersionType.DrawMode = System.Windows.Forms.DrawMode.OwnerDrawFixed; + this.CbbVersionType.FlatStyle = System.Windows.Forms.FlatStyle.Flat; + this.CbbVersionType.Font = new System.Drawing.Font("宋体", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134))); + this.CbbVersionType.FormattingEnabled = true; + this.CbbVersionType.Items.AddRange(new object[] { + "正式版", + "测试版", + "内测版", + "公测版"}); + this.CbbVersionType.Location = new System.Drawing.Point(319, 24); + this.CbbVersionType.MaxUndoRedoSteps = 50; + this.CbbVersionType.Name = "CbbVersionType"; + this.CbbVersionType.Size = new System.Drawing.Size(122, 27); + this.CbbVersionType.TabIndex = 49; + // + // cmbNewVer + // + this.cmbNewVer.BackColor = System.Drawing.Color.White; + this.cmbNewVer.EmptyText = ""; + this.cmbNewVer.Font = new System.Drawing.Font("宋体", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134))); + this.cmbNewVer.Location = new System.Drawing.Point(9, 23); + this.cmbNewVer.LongTime = 2000; + this.cmbNewVer.Margin = new System.Windows.Forms.Padding(4, 4, 4, 4); + this.cmbNewVer.MaxLength = 999999999; + this.cmbNewVer.MaxUndoRedoSteps = 50; + this.cmbNewVer.Multiline = false; + this.cmbNewVer.Name = "cmbNewVer"; + this.cmbNewVer.OnlyNumeric = false; + this.cmbNewVer.PasswordChar = '\0'; + this.cmbNewVer.ReadOnly = false; + this.cmbNewVer.SelectedText = ""; + this.cmbNewVer.SelectionLength = 0; + this.cmbNewVer.SelectionStart = 0; + this.cmbNewVer.Size = new System.Drawing.Size(223, 31); + this.cmbNewVer.TabIndex = 47; + this.cmbNewVer.TextAlign = System.Windows.Forms.HorizontalAlignment.Left; + this.cmbNewVer.ToolTip = ""; + this.cmbNewVer.WordWrap = true; + // + // txtDbUpdateDes + // + this.txtDbUpdateDes.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left) + | System.Windows.Forms.AnchorStyles.Right))); + this.txtDbUpdateDes.BackColor = System.Drawing.Color.White; + this.txtDbUpdateDes.EmptyText = ""; + this.txtDbUpdateDes.Enabled = false; + this.txtDbUpdateDes.Location = new System.Drawing.Point(10, 380); + this.txtDbUpdateDes.LongTime = 2000; + this.txtDbUpdateDes.MaxLength = 999999999; + this.txtDbUpdateDes.MaxUndoRedoSteps = 50; + this.txtDbUpdateDes.Multiline = true; + this.txtDbUpdateDes.Name = "txtDbUpdateDes"; + this.txtDbUpdateDes.OnlyNumeric = false; + this.txtDbUpdateDes.PasswordChar = '\0'; + this.txtDbUpdateDes.ReadOnly = false; + this.txtDbUpdateDes.SelectedText = ""; + this.txtDbUpdateDes.SelectionLength = 0; + this.txtDbUpdateDes.SelectionStart = 0; + this.txtDbUpdateDes.Size = new System.Drawing.Size(657, 133); + this.txtDbUpdateDes.TabIndex = 31; + this.txtDbUpdateDes.TextAlign = System.Windows.Forms.HorizontalAlignment.Left; + this.txtDbUpdateDes.ToolTip = ""; + this.txtDbUpdateDes.WordWrap = true; + // + // txtUpdateDes + // + this.txtUpdateDes.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom) + | System.Windows.Forms.AnchorStyles.Left) + | System.Windows.Forms.AnchorStyles.Right))); + this.txtUpdateDes.BackColor = System.Drawing.Color.White; + this.txtUpdateDes.EmptyText = ""; + this.txtUpdateDes.Location = new System.Drawing.Point(10, 195); + this.txtUpdateDes.LongTime = 2000; + this.txtUpdateDes.MaxLength = 999999999; + this.txtUpdateDes.MaxUndoRedoSteps = 50; + this.txtUpdateDes.Multiline = true; + this.txtUpdateDes.Name = "txtUpdateDes"; + this.txtUpdateDes.OnlyNumeric = false; + this.txtUpdateDes.PasswordChar = '\0'; + this.txtUpdateDes.ReadOnly = false; + this.txtUpdateDes.SelectedText = ""; + this.txtUpdateDes.SelectionLength = 0; + this.txtUpdateDes.SelectionStart = 0; + this.txtUpdateDes.Size = new System.Drawing.Size(657, 164); + this.txtUpdateDes.TabIndex = 30; + this.txtUpdateDes.TextAlign = System.Windows.Forms.HorizontalAlignment.Left; + this.txtUpdateDes.ToolTip = ""; + this.txtUpdateDes.WordWrap = true; + // + // cmbDbUpdateUrl + // + this.cmbDbUpdateUrl.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left) + | System.Windows.Forms.AnchorStyles.Right))); + this.cmbDbUpdateUrl.DrawMode = System.Windows.Forms.DrawMode.OwnerDrawFixed; + this.cmbDbUpdateUrl.Enabled = false; + this.cmbDbUpdateUrl.FlatStyle = System.Windows.Forms.FlatStyle.Flat; + this.cmbDbUpdateUrl.FormattingEnabled = true; + this.cmbDbUpdateUrl.Location = new System.Drawing.Point(9, 155); + this.cmbDbUpdateUrl.MaxUndoRedoSteps = 50; + this.cmbDbUpdateUrl.Name = "cmbDbUpdateUrl"; + this.cmbDbUpdateUrl.Size = new System.Drawing.Size(658, 22); + this.cmbDbUpdateUrl.TabIndex = 27; + // + // cmbProcUpdateUrl + // + this.cmbProcUpdateUrl.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left) + | System.Windows.Forms.AnchorStyles.Right))); + this.cmbProcUpdateUrl.DrawMode = System.Windows.Forms.DrawMode.OwnerDrawFixed; + this.cmbProcUpdateUrl.FlatStyle = System.Windows.Forms.FlatStyle.Flat; + this.cmbProcUpdateUrl.FormattingEnabled = true; + this.cmbProcUpdateUrl.Location = new System.Drawing.Point(9, 117); + this.cmbProcUpdateUrl.MaxUndoRedoSteps = 50; + this.cmbProcUpdateUrl.Name = "cmbProcUpdateUrl"; + this.cmbProcUpdateUrl.Size = new System.Drawing.Size(658, 22); + this.cmbProcUpdateUrl.TabIndex = 25; + // + // cmbNewDbVer + // + this.cmbNewDbVer.DrawMode = System.Windows.Forms.DrawMode.OwnerDrawFixed; + this.cmbNewDbVer.Enabled = false; + this.cmbNewDbVer.FlatStyle = System.Windows.Forms.FlatStyle.Flat; + this.cmbNewDbVer.Font = new System.Drawing.Font("宋体", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134))); + this.cmbNewDbVer.FormattingEnabled = true; + this.cmbNewDbVer.Location = new System.Drawing.Point(447, 24); + this.cmbNewDbVer.MaxUndoRedoSteps = 50; + this.cmbNewDbVer.Name = "cmbNewDbVer"; + this.cmbNewDbVer.Size = new System.Drawing.Size(122, 27); + this.cmbNewDbVer.TabIndex = 19; + // + // txtDelFileList + // + this.txtDelFileList.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom) + | System.Windows.Forms.AnchorStyles.Left) + | System.Windows.Forms.AnchorStyles.Right))); + this.txtDelFileList.EmptyText = ""; + this.txtDelFileList.Font = new System.Drawing.Font("Courier New", 10F); + this.txtDelFileList.Location = new System.Drawing.Point(10, 198); + this.txtDelFileList.Name = "txtDelFileList"; + this.txtDelFileList.OnlyInputText = false; + this.txtDelFileList.Size = new System.Drawing.Size(660, 233); + this.txtDelFileList.TabIndex = 37; + this.txtDelFileList.Text = ""; + this.txtDelFileList.WordWrap = true; + // + // txtKillProcList + // + this.txtKillProcList.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left) + | System.Windows.Forms.AnchorStyles.Right))); + this.txtKillProcList.EmptyText = ""; + this.txtKillProcList.Font = new System.Drawing.Font("Courier New", 10F); + this.txtKillProcList.Location = new System.Drawing.Point(10, 25); + this.txtKillProcList.Name = "txtKillProcList"; + this.txtKillProcList.OnlyInputText = false; + this.txtKillProcList.Size = new System.Drawing.Size(660, 155); + this.txtKillProcList.TabIndex = 36; + this.txtKillProcList.Text = ""; + this.txtKillProcList.WordWrap = true; + // + // txtMainProcPram + // + this.txtMainProcPram.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right))); + this.txtMainProcPram.BackColor = System.Drawing.Color.White; + this.txtMainProcPram.EmptyText = ""; + this.txtMainProcPram.Location = new System.Drawing.Point(577, 450); + this.txtMainProcPram.LongTime = 2000; + this.txtMainProcPram.MaxLength = 999999999; + this.txtMainProcPram.MaxUndoRedoSteps = 50; + this.txtMainProcPram.Multiline = false; + this.txtMainProcPram.Name = "txtMainProcPram"; + this.txtMainProcPram.OnlyNumeric = false; + this.txtMainProcPram.PasswordChar = '\0'; + this.txtMainProcPram.ReadOnly = false; + this.txtMainProcPram.SelectedText = ""; + this.txtMainProcPram.SelectionLength = 0; + this.txtMainProcPram.SelectionStart = 0; + this.txtMainProcPram.Size = new System.Drawing.Size(92, 21); + this.txtMainProcPram.TabIndex = 9; + this.txtMainProcPram.TextAlign = System.Windows.Forms.HorizontalAlignment.Left; + this.txtMainProcPram.ToolTip = ""; + this.txtMainProcPram.WordWrap = true; + // + // txtMainProcName + // + this.txtMainProcName.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left) + | System.Windows.Forms.AnchorStyles.Right))); + this.txtMainProcName.BackColor = System.Drawing.Color.White; + this.txtMainProcName.EmptyText = ""; + this.txtMainProcName.Location = new System.Drawing.Point(10, 450); + this.txtMainProcName.LongTime = 2000; + this.txtMainProcName.MaxLength = 999999999; + this.txtMainProcName.MaxUndoRedoSteps = 50; + this.txtMainProcName.Multiline = false; + this.txtMainProcName.Name = "txtMainProcName"; + this.txtMainProcName.OnlyNumeric = false; + this.txtMainProcName.PasswordChar = '\0'; + this.txtMainProcName.ReadOnly = false; + this.txtMainProcName.SelectedText = ""; + this.txtMainProcName.SelectionLength = 0; + this.txtMainProcName.SelectionStart = 0; + this.txtMainProcName.Size = new System.Drawing.Size(561, 21); + this.txtMainProcName.TabIndex = 3; + this.txtMainProcName.TextAlign = System.Windows.Forms.HorizontalAlignment.Left; + this.txtMainProcName.ToolTip = ""; + this.txtMainProcName.WordWrap = true; + // + // txtUserList + // + this.txtUserList.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left) + | System.Windows.Forms.AnchorStyles.Right))); + this.txtUserList.DrawMode = System.Windows.Forms.DrawMode.OwnerDrawFixed; + this.txtUserList.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList; + this.txtUserList.FlatStyle = System.Windows.Forms.FlatStyle.Flat; + this.txtUserList.Font = new System.Drawing.Font("Courier New", 10.5F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0))); + this.txtUserList.FormattingEnabled = true; + this.txtUserList.Location = new System.Drawing.Point(9, 489); + this.txtUserList.MaxUndoRedoSteps = 50; + this.txtUserList.Name = "txtUserList"; + this.txtUserList.Size = new System.Drawing.Size(599, 24); + this.txtUserList.TabIndex = 10; + // + // TxtUpdateDes_Html + // + this.TxtUpdateDes_Html.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom) + | System.Windows.Forms.AnchorStyles.Left) + | System.Windows.Forms.AnchorStyles.Right))); + this.TxtUpdateDes_Html.EmptyText = ""; + this.TxtUpdateDes_Html.Font = new System.Drawing.Font("Courier New", 10F); + this.TxtUpdateDes_Html.Location = new System.Drawing.Point(9, 35); + this.TxtUpdateDes_Html.Name = "TxtUpdateDes_Html"; + this.TxtUpdateDes_Html.OnlyInputText = false; + this.TxtUpdateDes_Html.Size = new System.Drawing.Size(660, 481); + this.TxtUpdateDes_Html.TabIndex = 33; + this.TxtUpdateDes_Html.Text = ""; + this.TxtUpdateDes_Html.WordWrap = true; + // // frmUpdateFile // this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 12F); @@ -953,5 +997,8 @@ namespace LiveUpdate private ryControls.Controls.RichTextBox2 txtDelFileList; private ryControls.TextBoxEx2 cmbNewVer; private System.Windows.Forms.Button BtnPasteFromMD; + private ryControls.RyComboBox CbbVersionType; + private System.Windows.Forms.Label label10; + private System.Windows.Forms.Button BtnDefUpdateLog; } } \ No newline at end of file diff --git a/Source/OnLineUpgradeConfig/frmUpdateFile.cs b/Source/OnLineUpgradeConfig/frmUpdateFile.cs index 1a62b2d..4520489 100644 --- a/Source/OnLineUpgradeConfig/frmUpdateFile.cs +++ b/Source/OnLineUpgradeConfig/frmUpdateFile.cs @@ -18,6 +18,7 @@ using WinAPI; using RyWeb; using System.IO.Compression; using static System.Windows.Forms.VisualStyles.VisualStyleElement; +using System.Diagnostics; namespace LiveUpdate { @@ -96,6 +97,7 @@ namespace LiveUpdate var updatelogs_folder = UpdateFilesDir + "\\WebUpdateLogs"; Json json= new Json(RyFiles.ReadAllText(filePath)); cmbNewVer.Text = json.GetJsonValue("SoftVer", ""); + CbbVersionType.Text = json.GetJsonValue("VersionType", ""); cmbNewDbVer.Text = json.GetJsonValue("DbVer", ""); cmbProcUpdateUrl.Text = json.GetJsonValue("FileUpdateUrl", ""); dtNewProcDate.Value = ConvertDateTime(json.GetJsonValue("SoftDate", ""), DateTime.Now); @@ -184,6 +186,7 @@ namespace LiveUpdate JObject json = new JObject { ["SoftVer"] = cmbNewVer.Text, + ["VersionType"] = CbbVersionType.Text, ["DbVer"] = cmbNewDbVer.Text, ["FileUpdateUrl"] = ProcUpdateUrl, ["DbUpdateUrl"] = cmbDbUpdateUrl.Text, @@ -236,7 +239,7 @@ namespace LiveUpdate { case DialogResult.Yes: QuickWeb web = new QuickWeb(); - web.Post("http://gs2.3h3.com:1881/process", "a=send&touser=" +web.UrlEncode(user.UserList.Replace(",",";")) + "&type="+ ryMessageConst.MsType.MustUpdate + + web.Post("http://gs2.dangyou.com:1881/process", "a=send&touser=" +web.UrlEncode(user.UserList.Replace(",",";")) + "&type="+ ryMessageConst.MsType.MustUpdate + "&msg=" + web.UrlEncode("http://192.168.1.191/OnlineUpgrade/" + System.IO.Path.GetFileName(update_fullpath))); break; } @@ -594,5 +597,10 @@ namespace LiveUpdate TxtUpdateDes_Html.SelectedText= txt.Trim(); } } + + private void BtnDefUpdateLog_Click(object sender, EventArgs e) + { + TxtUpdateDes_Html.Text ="

[改进]一些功能改进。

\r\n

[修复]修复了一些BUG。

"; + } } } diff --git a/Source/RaUI/Common/Extend/VarExtension.cs b/Source/RaUI/Common/Extend/VarExtension.cs index e84de55..f84e2f3 100644 --- a/Source/RaUI/Common/Extend/VarExtension.cs +++ b/Source/RaUI/Common/Extend/VarExtension.cs @@ -161,6 +161,7 @@ namespace ryCommon /// static public int IndexOfEx(this string input, string value) { + if (input == null) { return -1; } return input.IndexOf(value, StringComparison.OrdinalIgnoreCase); } /// diff --git a/Source/RaUI/Common/FileFuns/BigFileOp.cs b/Source/RaUI/Common/FileFuns/BigFileOp.cs index d567799..18e4573 100644 --- a/Source/RaUI/Common/FileFuns/BigFileOp.cs +++ b/Source/RaUI/Common/FileFuns/BigFileOp.cs @@ -57,18 +57,22 @@ namespace ryCommon /// public event CancelEventHandler OnCanel; /// + /// 是否跳过相同文件,默认不跳过(根据文件大小和修改时间来判断) + /// + public bool SkipSameFiles { get; set; } = false; + /// /// 大文件按流复制文件,支持自动创建目标文件夹。 true:复制成功 false:复制失败 /// - /// 原始文件路径 + /// 原始文件路径 /// 复制目标文件路径 /// 携带的参数(可选) /// - public bool CopyBigFile(string soucrePath, string targetPath,object Tag=null) + public bool CopyBigFile(string sourcePath, string targetPath,object Tag=null) { if (OnCanelCopy != null) { CancelEventArgs e1 = new CancelEventArgs(); - OnCanelCopy?.Invoke(this, e1, soucrePath, targetPath); + OnCanelCopy?.Invoke(this, e1, sourcePath, targetPath); if (e1.Cancel) { return true; @@ -76,20 +80,33 @@ namespace ryCommon } try { - if (!System.IO.File.Exists(soucrePath)) + if (!System.IO.File.Exists(sourcePath)) { return false; } - if (System.IO.File.Exists(targetPath)) + if (SkipSameFiles) { - if (RyFiles.DeleteFile(targetPath) != 0) + if (System.IO.File.Exists(targetPath)) { - return false; + try + { + var target_info = new System.IO.FileInfo(targetPath); + var source_info = new System.IO.FileInfo(sourcePath); + if (target_info.Length == source_info.Length && target_info.LastWriteTimeUtc == source_info.LastWriteTimeUtc) + { + return true; + } + } + catch { } + if (RyFiles.DeleteFile(targetPath) != 0) + { + return false; + } } } var TranSize = 1024 * 1024 * 2;//每次读取2M //读取复制文件流 - using (FileStream fsRead = new FileStream(soucrePath, FileMode.Open, FileAccess.Read)) + using (FileStream fsRead = new FileStream(sourcePath, FileMode.Open, FileAccess.Read)) { RyFiles.CreateDirectory(System.IO.Path.GetDirectoryName(targetPath)); OnFileProgress?.Invoke(0, fsRead.Length, 0,0, Tag); @@ -151,7 +168,7 @@ namespace ryCommon return false; } } - var from_dt = RyFiles.GetFileDate(soucrePath); + var from_dt = RyFiles.GetFileDate(sourcePath); var file_dt = new sType.FileTime { LastWriteTime = from_dt.LastWriteTime, diff --git a/Source/RaUI/Common/FileFuns/Hosts.cs b/Source/RaUI/Common/FileFuns/Hosts.cs index 7c63c5c..582a7be 100644 --- a/Source/RaUI/Common/FileFuns/Hosts.cs +++ b/Source/RaUI/Common/FileFuns/Hosts.cs @@ -77,40 +77,54 @@ namespace ryCommon bool isAdd = false;//是否有增加数据到hosts里 for (int i = 0; i < rule_list.Count; i++) { - if (rule_list[i].Comment.Length > 0) { continue; } + var rule_item = rule_list[i]; + if (rule_item.Comment.Length > 0) { continue; } bool HaveRecord = false; for (int m = sys_list.Count - 1; m >= 0; m--) //去host文件里查找是否已含有该内容 { if (sys_list[m].Comment.Length > 0) { continue; } - if (rule_list[i].Domain.ToLower() == sys_list[m].Domain.ToLower()) + if (rule_item.Domain.ToLower() == sys_list[m].Domain.ToLower()) { - if (rule_list[i].IP.Length == 0 && rule_list[i].IsDel) + if (rule_item.IsDel) { - sys_list.RemoveAt(m); - HaveRecord = true; + if (rule_item.IP.Length == 0) //如果ip为空,则删除所有包含该域名的项 + { + sys_list.RemoveAt(m); + HaveRecord = true; + } + else if (rule_item.IP == sys_list[m].IP) + { + sys_list.RemoveAt(m); + HaveRecord = true; + } } else { if (rule_list[i].IP != sys_list[m].IP) //如果同样域名对应的ip不一样,则删除该项,然后再插入新的ip { sys_list.RemoveAt(m); - HaveRecord = false; } - else + else if (rule_list[i].IP == sys_list[m].IP) { - if (rule_list[i].IsDel) //如果ip和网址一致,并且标注为删除,则删除 - { - sys_list.RemoveAt(m); - } HaveRecord = true; } } } } - if (!HaveRecord) + if (rule_list[i].IsDel) { - isAdd = true; - sys_list.Add(rule_list[i]); + if (HaveRecord) + { + isAdd = true; + } + } + else + { + if (!HaveRecord) + { + isAdd = true; + sys_list.Add(rule_list[i]); + } } } if (isAdd) @@ -122,6 +136,7 @@ namespace ryCommon sys_content = ""; for (int i = 0; i < sys_list.Count; i++) { + if (sys_list[i].IsDel) { continue; } if (sys_content.Length > 0) { sys_content += "\r\n"; } if (sys_list[i].Comment.Length > 0) { diff --git a/Source/RaUI/Common/FileFuns/RyFiles.cs b/Source/RaUI/Common/FileFuns/RyFiles.cs index b446731..c89d763 100644 --- a/Source/RaUI/Common/FileFuns/RyFiles.cs +++ b/Source/RaUI/Common/FileFuns/RyFiles.cs @@ -380,6 +380,36 @@ namespace ryCommon { return file_op.CopyFolder(fromDir, ToDir); } + /// + /// 复制或剪切文件列表到剪切板 + /// + /// + /// + public static void CopyOrCutFileToClipboard(string[] files,bool cut) + { + DataObject data = new DataObject(DataFormats.FileDrop, files); + MemoryStream memo = new MemoryStream(4); + memo = new MemoryStream(4); byte[] bytes = new byte[] { (byte)(cut ? 2 : 5), 0, 0, 0 }; + memo.Write(bytes, 0, bytes.Length); + data.SetData("Preferred DropEffect", memo); + Clipboard.SetDataObject(data); + } + /// + /// 复制文件列表到剪切板 + /// + /// + public static void CopyFileToClipboard(string[] files) + { + CopyOrCutFileToClipboard(files, false); + } + /// + /// 剪切文件列表到剪切板 + /// + /// + public static void CutFileToClipboard(string[] files) + { + CopyOrCutFileToClipboard(files, true); + } #endregion 【复制文件操作】 #region 【重命名文件】 diff --git a/Source/RaUI/Common/FileFuns/RyImage.cs b/Source/RaUI/Common/FileFuns/RyImage.cs index 3640f43..fa15507 100644 --- a/Source/RaUI/Common/FileFuns/RyImage.cs +++ b/Source/RaUI/Common/FileFuns/RyImage.cs @@ -1053,13 +1053,13 @@ namespace ryCommon { //等宽,计算高 size.Width = i.Width; - size.Height = (i.Width / scale).ToInt(); + size.Height = Math.Truncate(i.Width / scale).ToInt(); } else { //等高,计算宽 size.Height = i.Height; - size.Width = (i.Height * scale).ToInt(); + size.Width = Math.Truncate(i.Height * scale).ToInt(); } //如果原图片和新图片的比例不同,先裁剪或填充后,再缩放 using (System.Drawing.Image cropOrFill = i.CropOrFill(size.Width, size.Height, background, interpolationMode)) diff --git a/Source/RaUI/Common/FileFuns/RySetting.cs b/Source/RaUI/Common/FileFuns/RySetting.cs index 8192fe7..c39cf69 100644 --- a/Source/RaUI/Common/FileFuns/RySetting.cs +++ b/Source/RaUI/Common/FileFuns/RySetting.cs @@ -1,4 +1,5 @@ using ryCommon.Pram; +using ryControls; using System; using System.Collections.Generic; using System.Linq; diff --git a/Source/RaUI/Common/MyDb/ryQuickSQL.cs b/Source/RaUI/Common/MyDb/ryQuickSQL.cs index 8ada590..877fb3b 100644 --- a/Source/RaUI/Common/MyDb/ryQuickSQL.cs +++ b/Source/RaUI/Common/MyDb/ryQuickSQL.cs @@ -1,4 +1,6 @@ -using System; +using Newtonsoft.Json.Linq; +using ryCommon; +using System; using System.Collections.Generic; using System.Xml.Linq; using static ryCommon.RyRegedit; @@ -254,7 +256,10 @@ namespace ryCommonDb /// ///
public List List_calcparam { get; set; } = new List(); - + /// + /// 是否将时间类型转为时间戳 + /// + public bool DateToTimeStamp { get; set; } = true; /// /// 输出多条件搜索。 /// @@ -333,6 +338,17 @@ namespace ryCommonDb { tmpSQL += true_false?"true":"false"; } + else if (item.value is DateTime dt) + { + if (DateToTimeStamp) + { + tmpSQL += dt.ToInt64(); + } + else + { + tmpSQL += RyWeb.WebDecode.UrlEncode(dt.ToString("yyyy-MM-dd HH:mm:ss"), System.Text.Encoding.UTF8); + } + } else { tmpSQL +=RyWeb.WebDecode.UrlEncode(item.value.ToString(), System.Text.Encoding.UTF8); @@ -341,6 +357,55 @@ namespace ryCommonDb return tmpSQL; } /// + /// 根据输入的内容,生成Json数据 + /// + /// + public JObject GetJsonData() + { + JObject jo = new JObject(); + for (int i = 0; i < List.Count; i++) + { + SQLIitem item = List[i]; + var name = item.Field.TrimStart('[').TrimEnd(']'); + if (item.value is long int1) + { + jo[name] = int1; + } + else if (item.value is int @int) + { + jo[name] = @int; + } + else if (item.value is decimal dec) + { + jo[name] = dec; + } + else if (item.value is double dou) + { + jo[name] = dou; + } + else if (item.value is bool true_false) + { + jo[name] = true_false; + } + else if (item.value is DateTime dt) + { + if (DateToTimeStamp) + { + jo[name] = dt.ToInt64(); + } + else + { + jo[name] = dt; + } + } + else + { + jo[name]= item.value.ToString(); + } + } + return jo; + } + /// /// 获取插入SQL语句 /// /// diff --git a/Source/RaUI/Common/Shell/API.cs b/Source/RaUI/Common/Shell/API.cs index 108b5aa..8020474 100644 --- a/Source/RaUI/Common/Shell/API.cs +++ b/Source/RaUI/Common/Shell/API.cs @@ -1,14 +1,22 @@ +//򿪷lc_mtt +//CSDNͣhttp://lemony.cnblogs.com +//ҳhttp://www.3lsoft.com +//ע˴ֹҵ;޸߷һݣлл +//---------------- Դ磬Ҹ ---------------- + using System; using System.Collections.Generic; using System.Text; using System.Runtime.InteropServices; -namespace WinShell { +namespace WinShell +{ /// /// /// - public class API { - #region API ɤJ + public class API + { + #region API /// /// /// @@ -104,17 +112,80 @@ namespace WinShell { IntPtr hwnd, IntPtr lptpm); - #endregion + [DllImport("Shell32.Dll")] + private static extern bool SHGetSpecialFolderPath( + IntPtr hwndOwner, + StringBuilder lpszPath, + ShellSpecialFolders nFolder, + bool fCreate); + #endregion /// - ///Shell + /// Shell /// - public static IShellFolder GetDesktopFolder(/*out IntPtr ppshf*/) { - IntPtr ppshf; + public static IShellFolder GetDesktopFolder() + { + return GetDesktopFolder(out _); + } + /// + /// Shell + /// + public static IShellFolder GetDesktopFolder(out IntPtr ppshf) + { SHGetDesktopFolder(out ppshf); Object obj = Marshal.GetObjectForIUnknown(ppshf); return (IShellFolder)obj; } + + /// + /// ȡ· + /// + public static string GetPathByIShell(IShellFolder Root, IntPtr pidlSub) + { + IntPtr strr = Marshal.AllocCoTaskMem(MAX_PATH * 2 + 4); + Marshal.WriteInt32(strr, 0, 0); + StringBuilder buf = new StringBuilder(MAX_PATH); + Root.GetDisplayNameOf(pidlSub, SHGNO.FORADDRESSBAR | SHGNO.FORPARSING, strr); + API.StrRetToBuf(strr, pidlSub, buf, MAX_PATH); + Marshal.FreeCoTaskMem(strr); + return buf.ToString(); + } + + /// + /// ȡʾ + /// + public static string GetNameByIShell(IShellFolder Root, IntPtr pidlSub) + { + IntPtr strr = Marshal.AllocCoTaskMem(MAX_PATH * 2 + 4); + Marshal.WriteInt32(strr, 0, 0); + StringBuilder buf = new StringBuilder(MAX_PATH); + Root.GetDisplayNameOf(pidlSub, SHGNO.INFOLDER, strr); + API.StrRetToBuf(strr, pidlSub, buf, MAX_PATH); + Marshal.FreeCoTaskMem(strr); + return buf.ToString(); + } + + /// + /// PIDL ȡʾ + /// + public static string GetNameByPIDL(IntPtr pidl) + { + SHFILEINFO info = new SHFILEINFO(); + API.SHGetFileInfo(pidl, 0, ref info, Marshal.SizeOf(typeof(SHFILEINFO)), + SHGFI.PIDL | SHGFI.DISPLAYNAME | SHGFI.TYPENAME); + return info.szDisplayName; + } + + /// + /// ȡļе· + /// + public static string GetSpecialFolderPath(IntPtr hwnd, ShellSpecialFolders nFolder) + { + StringBuilder sb = new StringBuilder(MAX_PATH); + SHGetSpecialFolderPath(hwnd, sb, nFolder, false); + return sb.ToString(); + } + /// /// ·ȡ IShellFolder PIDL /// @@ -126,30 +197,14 @@ namespace WinShell { desktop.BindToObject(Pidl, IntPtr.Zero, ref Guids.IID_IShellFolder, out IFolder); return IFolder; } - /// - /// - /// - /// - /// - /// - public static string GetNameByIShell(IShellFolder Root, IntPtr pidlSub) { - IntPtr strr = Marshal.AllocCoTaskMem(MAX_PATH * 2 + 4); - Marshal.WriteInt32(strr, 0, 0); - StringBuilder buf = new StringBuilder(MAX_PATH); - Root.GetDisplayNameOf(pidlSub, SHGNO.INFOLDER, strr); - API.StrRetToBuf(strr, pidlSub, buf, MAX_PATH); - return buf.ToString(); - } /// - /// + /// ·ȡ IShellFolder /// - public static string GetNameByPIDL(IntPtr pidl) { - SHFILEINFO info = new SHFILEINFO(); - API.SHGetFileInfo(pidl, 0, ref info, Marshal.SizeOf(typeof(SHFILEINFO)), - SHGFI.PIDL | SHGFI.DISPLAYNAME | SHGFI.TYPENAME); - return info.szDisplayName; + public static IShellFolder GetShellFolder(IShellFolder desktop, string path) + { + IntPtr Pidl; + return GetShellFolder(desktop, path, out Pidl); } - } } diff --git a/Source/RaUI/Common/Shell/CShellFolder.cs b/Source/RaUI/Common/Shell/CShellFolder.cs index 5a843e3..6f0d126 100644 --- a/Source/RaUI/Common/Shell/CShellFolder.cs +++ b/Source/RaUI/Common/Shell/CShellFolder.cs @@ -5,6 +5,7 @@ using System.Runtime.InteropServices; using System.Drawing; using System.IO; using System.Windows.Forms; +using RaUI.UI.LayeredForm; #pragma warning disable CS1591 // 缺少对公共可见类型或成员的 XML 注释 namespace WinShell { @@ -172,11 +173,11 @@ namespace WinShell { { OnFetchFolder(this, name); IShellFolder IParent = Root; + //桌面的真实路径的 PIDL + //Root.BindToObject(pidlSub, IntPtr.Zero, ref Guids.IID_IShellFolder, out IParent); IntPtr PIDL = pidlSub; //存放 PIDL 的数组 - IntPtr[] pidls = new IntPtr[1]; - pidls[0] = PIDL; - + IntPtr[] pidls = [PIDL]; //得到 IContextMenu 接口 IntPtr iContextMenuPtr = IntPtr.Zero; iContextMenuPtr = IParent.GetUIObjectOf(IntPtr.Zero, (uint)pidls.Length, diff --git a/Source/RaUI/Common/Shell/Enums.cs b/Source/RaUI/Common/Shell/Enums.cs index 084e476..a335eee 100644 --- a/Source/RaUI/Common/Shell/Enums.cs +++ b/Source/RaUI/Common/Shell/Enums.cs @@ -1,3 +1,9 @@ +//򿪷lc_mtt +//CSDNͣhttp://lemony.cnblogs.com +//ҳhttp://www.3lsoft.com +//ע˴ֹҵ;޸߷һݣлл +//---------------- Դ磬Ҹ ---------------- + using System; using System.Collections.Generic; using System.Text; @@ -208,4 +214,71 @@ namespace WinShell LAYOUTRTL = 0x8000 } + [Flags()] + public enum ShellSpecialFolders + { + DESKTOP = 0x0000, // + INTERNET = 0x0001, + PROGRAMS = 0x0002, // Start Menu\Programs + CONTROLS = 0x0003, // My Computer\Control Panel + PRINTERS = 0x0004, // My Computer\Printers + PERSONAL = 0x0005, // My Documents + FAVORITES = 0x0006, // \Favorites + STARTUP = 0x0007, // Start Menu\Programs\Startup + RECENT = 0x0008, // \Recent + SENDTO = 0x0009, // \SendTo + BITBUCKET = 0x000a, // \Recycle Bin + STARTMENU = 0x000b, // \Start Menu + MYDOCUMENTS = 0x000c, // logical "My Documents" desktop icon + MYMUSIC = 0x000d, // "My Music" folder + MYVIDEO = 0x000e, // "My Videos" folder + DESKTOPDIRECTORY = 0x0010, // \Desktop + DRIVES = 0x0011, // My Computer + NETWORK = 0x0012, // Network Neighborhood (My Network Places) + NETHOOD = 0x0013, // \nethood + FONTS = 0x0014, // windows\fonts + TEMPLATES = 0x0015, + COMMON_STARTMENU = 0x0016, // All Users\Start Menu + COMMON_PROGRAMS = 0X0017, // All Users\Start Menu\Programs + COMMON_STARTUP = 0x0018, // All Users\Startup + COMMON_DESKTOPDIRECTORY = 0x0019, // All Users\Desktop + APPDATA = 0x001a, // \Application Data + PRINTHOOD = 0x001b, // \PrintHood + LOCAL_APPDATA = 0x001c, // \Local Settings\Applicaiton Data (non roaming) + ALTSTARTUP = 0x001d, // non localized startup + COMMON_ALTSTARTUP = 0x001e, // non localized common startup + COMMON_FAVORITES = 0x001f, + INTERNET_CACHE = 0x0020, + COOKIES = 0x0021, + HISTORY = 0x0022, + COMMON_APPDATA = 0x0023, // All Users\Application Data + WINDOWS = 0x0024, // GetWindowsDirectory() + SYSTEM = 0x0025, // GetSystemDirectory() + PROGRAM_FILES = 0x0026, // C:\Program Files + MYPICTURES = 0x0027, // C:\Program Files\My Pictures + PROFILE = 0x0028, // USERPROFILE + SYSTEMX86 = 0x0029, // x86 system directory on RISC + PROGRAM_FILESX86 = 0x002a, // x86 C:\Program Files on RISC + PROGRAM_FILES_COMMON = 0x002b, // C:\Program Files\Common + PROGRAM_FILES_COMMONX86 = 0x002c, // x86 Program Files\Common on RISC + COMMON_TEMPLATES = 0x002d, // All Users\Templates + COMMON_DOCUMENTS = 0x002e, // All Users\Documents + COMMON_ADMINTOOLS = 0x002f, // All Users\Start Menu\Programs\Administrative Tools + ADMINTOOLS = 0x0030, // \Start Menu\Programs\Administrative Tools + CONNECTIONS = 0x0031, // Network and Dial-up Connections + COMMON_MUSIC = 0x0035, // All Users\My Music + COMMON_PICTURES = 0x0036, // All Users\My Pictures + COMMON_VIDEO = 0x0037, // All Users\My Video + RESOURCES = 0x0038, // Resource Direcotry + RESOURCES_LOCALIZED = 0x0039, // Localized Resource Direcotry + COMMON_OLINKS = 0x003a, // Links to All Users OEM specific apps + CDBURN_AREA = 0x003b, // USERPROFILE\Local Settings\Application Data\Microsoft\CD Burning + COMPUTERSNEARME = 0x003d, // Computers Near Me (computered from Workgroup membership) + FLAG_CREATE = 0x8000, // combine with value to force folder creation in SHGetFolderPath() + FLAG_DONT_VERIFY = 0x4000, // combine with value to return an unverified folder path + FLAG_NO_ALIAS = 0x1000, // combine with value to insure non-alias versions of the pidl + FLAG_PER_USER_INIT = 0x0800, // combine with value to indicate per-user init (eg. upgrade) + FLAG_MASK = 0xFF00, // mask for all possible flag values + } + } diff --git a/Source/RaUI/Common/SysFuns/ApkOp.cs b/Source/RaUI/Common/SysFuns/ApkOp.cs index 7867ae3..6820688 100644 --- a/Source/RaUI/Common/SysFuns/ApkOp.cs +++ b/Source/RaUI/Common/SysFuns/ApkOp.cs @@ -165,6 +165,7 @@ namespace ryCommon if(item == apk_icon) { list_icon.RemoveAt(i); } } } + list_icon.Insert(0, apk_icon); if (list_icon.Count > 0) { apk_icon = list_icon[list_icon.Count - 1]; } Random rd = new Random(Guid.NewGuid().GetHashCode()); string apkicon_savepath = Cache_Folder + "\\apkicon_" +rySafe.MD5Sha1.GetMD5(apk_file +"_"+ DateTime.Now.ToInt64()+"_"+ rd.Next(1,99999)) + ".png"; diff --git a/Source/RaUI/Common/SysFuns/HotkeyValue.cs b/Source/RaUI/Common/SysFuns/HotkeyValue.cs index 92b7459..3ad6102 100644 --- a/Source/RaUI/Common/SysFuns/HotkeyValue.cs +++ b/Source/RaUI/Common/SysFuns/HotkeyValue.cs @@ -107,11 +107,11 @@ namespace SysFuns Keys m_Modifiers = Modifiers; if ((m_Modifiers & Keys.Alt) != 0) { m_key |= 1; } - else if ((m_Modifiers & Keys.Control) != 0) + if ((m_Modifiers & Keys.Control) != 0) { m_key |= 2; } - else if ((m_Modifiers & Keys.Shift) != 0) + if ((m_Modifiers & Keys.Shift) != 0) { m_key |= 4; } - else if ((m_Modifiers & Keys.LWin) != 0) + if ((m_Modifiers & Keys.LWin) != 0) { m_key |= 8; } this.Modifiers_Int = m_key; } @@ -136,6 +136,37 @@ namespace SysFuns T_Modifiers = item[0].ToInt(0); T_Key = (Keys)item[1].ToInt(0); } + else if (item.Length <= 4) + { + var modifiers = "+"; + for (int i = 0; i < item.Length - 1; i++) + { + modifiers += item[i] + "+"; + } + var m_Modifiers = Keys.None; + if (modifiers.IndexOfEx("+ctrl+") >= 0) + { + m_Modifiers |= Keys.Control; + } + if (modifiers.IndexOfEx("+alt+") >= 0) + { + m_Modifiers |= Keys.Alt; + } + if (modifiers.IndexOfEx("+shift+") >= 0) + { + m_Modifiers |= Keys.Shift; + } + if (modifiers.IndexOfEx("+win+") >= 0) + { + m_Modifiers |= Keys.LWin; + } + var keyString = item[item.Length - 1]; + if (Enum.TryParse(keyString, out Keys key)) + { + LoadHotKey(m_Modifiers, key); + return; + } + } } catch { diff --git a/Source/RaUI/Common/SysFuns/WinHotReg.cs b/Source/RaUI/Common/SysFuns/WinHotReg.cs index a389f9d..c316a3f 100644 --- a/Source/RaUI/Common/SysFuns/WinHotReg.cs +++ b/Source/RaUI/Common/SysFuns/WinHotReg.cs @@ -182,6 +182,17 @@ namespace SysFuns return result; } /// + /// + /// + /// + /// + /// + public bool RegHotKey(int id, string hotkey) + { + HotkeyValue hotkeyValue =new HotkeyValue(hotkey); + return RegHotKey(id, hotkeyValue.Modifiers_Int, hotkeyValue.KeyCode); + } + /// /// 注册热键 /// /// diff --git a/Source/RaUI/ExtendUI/_SCREEN_CAPTURE/ImageProcessBox.cs b/Source/RaUI/ExtendUI/_SCREEN_CAPTURE/ImageProcessBox.cs index e0c88a7..b4569f6 100644 --- a/Source/RaUI/ExtendUI/_SCREEN_CAPTURE/ImageProcessBox.cs +++ b/Source/RaUI/ExtendUI/_SCREEN_CAPTURE/ImageProcessBox.cs @@ -427,14 +427,22 @@ namespace _SCREEN_CAPTURE /// protected override void OnPaint(PaintEventArgs e) { Graphics g = e.Graphics; - if (this.baseImage != null) { - g.DrawImage(m_bmpDark, 0, 0); - g.DrawImage(this.baseImage, this.selectedRectangle, this.selectedRectangle, GraphicsUnit.Pixel); + try + { + if (this.baseImage != null) + { + if (!this.IsDisposed) + { + g.DrawImage(m_bmpDark, 0, 0); + g.DrawImage(this.baseImage, this.selectedRectangle, this.selectedRectangle, GraphicsUnit.Pixel); + } + } + this.DrawOperationBox(g); + if (this.baseImage != null && !isDrawed && !isMoving && m_bMouseEnter && isShowInfo) + DrawInfo(e.Graphics); + base.OnPaint(e); } - this.DrawOperationBox(g); - if (this.baseImage != null && !isDrawed && !isMoving && m_bMouseEnter && isShowInfo) - DrawInfo(e.Graphics); - base.OnPaint(e); + catch { } } /// /// 绘制操作框 diff --git a/Source/RaUI/ExtendUI/myUpdate/LiveUpdate_EventArgs.cs b/Source/RaUI/ExtendUI/myUpdate/LiveUpdate_EventArgs.cs index 000632d..24bed6d 100644 --- a/Source/RaUI/ExtendUI/myUpdate/LiveUpdate_EventArgs.cs +++ b/Source/RaUI/ExtendUI/myUpdate/LiveUpdate_EventArgs.cs @@ -24,6 +24,10 @@ namespace LiveUpdate /// public string UpdateVer;//版本 /// + /// 版本类型 + /// + public string VersionType;//版本类型 + /// /// 更新日期 /// public string UpdateDate;//更新日期 diff --git a/Source/RaUI/ExtendUI/myUpdate/clsLiveUpdate.cs b/Source/RaUI/ExtendUI/myUpdate/clsLiveUpdate.cs index 128ecad..f269a2b 100644 --- a/Source/RaUI/ExtendUI/myUpdate/clsLiveUpdate.cs +++ b/Source/RaUI/ExtendUI/myUpdate/clsLiveUpdate.cs @@ -295,12 +295,12 @@ namespace LiveUpdate SoftUpdateDesUrl = jo.GetJsonValue("SoftUpdateDesUrl", ""); //数据库更新描述 DbUpdateDes = jo.GetJsonValue("DbUpdateDes", ""); - + //激发事件 OnReadComplete_T(); //更新标志,1表示软件更新,2表示数据库更新 int UpdateMarket = 0;//更新标志 - UpdateInfo myUpdate=new UpdateInfo(); + UpdateInfo myUpdate = new UpdateInfo(); myUpdate.UpdateDate = ""; myUpdate.UpdateDes = ""; myUpdate.UpdateDes_Url = ""; @@ -308,17 +308,17 @@ namespace LiveUpdate myUpdate.UpdateType = ""; myUpdate.UpdateUrl = ""; var m_UpdateUserList = jo.GetJsonValue("UpdateUserList", ""); - if(m_UpdateUserList.Length>0) + if (m_UpdateUserList.Length > 0) { m_UpdateUserList = "|" + m_UpdateUserList.Replace(";", "|") + "|"; } if (RySoft.CompareVer(MySoftVer, MySoftRVer, SoftVer, ReVer) == 1) { - var ConfigUrl= jo.GetJsonValue("ConfigUrl", ""); - if(ConfigUrl.Length>0) + var ConfigUrl = jo.GetJsonValue("ConfigUrl", ""); + if (ConfigUrl.Length > 0) { var http_config = web.Get(ConfigUrl); - if(http_config.StatusCode== HttpStatusCode.OK) + if (http_config.StatusCode == HttpStatusCode.OK) { try { @@ -328,7 +328,7 @@ namespace LiveUpdate //在下载升级包前首先要下载的内容 myUpdate.FirstDownList = jo_config.GetJsonValue("FirstDownList", ""); Storage storage = new Storage(); - storage.AddNode2("id","MainProcName"); + storage.AddNode2("id", "MainProcName"); storage.SetAttrValue("Value", jo_config.GetJsonValue("MainProcName", "")); storage.AddNode2("id", "MainProcPram"); storage.SetAttrValue("Value", jo_config.GetJsonValue("MainProcPram", "")); @@ -345,6 +345,7 @@ namespace LiveUpdate myUpdate.UpdateDate = SoftDate; myUpdate.UpdateDes = SoftUpdateDes; myUpdate.UpdateVer = SoftVersion; + myUpdate.VersionType = jo.GetJsonValue("VersionType", ""); myUpdate.UpdateType = "soft"; myUpdate.UpdateDes_Url = SoftUpdateDesUrl; if (FileVerUpdateUrl.Length > 0) @@ -404,7 +405,8 @@ namespace LiveUpdate OnNoUpdate_T(); } } - catch { + catch + { UpdateError.ErrorId = 2; UpdateError.ErrorStr = "更新错误,读取远程文件失败"; OnHappenError_T(UpdateError); @@ -412,6 +414,12 @@ namespace LiveUpdate return; } } + else { + UpdateError.ErrorId = 3; + UpdateError.ErrorStr = "更新错误,读取远程文件失败2"; + OnHappenError_T(UpdateError); + OnNoUpdate_T(); + } } Thread threadDown; /// diff --git a/Source/RaUI/ExtendUI/myUpdate/frmUpdate.cs b/Source/RaUI/ExtendUI/myUpdate/frmUpdate.cs index 15764b4..bf2c6fd 100644 --- a/Source/RaUI/ExtendUI/myUpdate/frmUpdate.cs +++ b/Source/RaUI/ExtendUI/myUpdate/frmUpdate.cs @@ -92,7 +92,7 @@ namespace LiveUpdate Capion = "发现更新的数据库,升级到最新版数据库,可以获取更全的显示内容。"; } UpdateDate = ConvertDateStr(e.UpdateDate, "未知"); - UpdateVer = e.UpdateVer; + UpdateVer = e.UpdateVer+(e.VersionType.Length==0?"":" "+e.VersionType); if (e.UpdateDes_Url != "" && e.UpdateDes_Url.IndexOf("http", StringComparison.OrdinalIgnoreCase) == 0) { extendedWebBrowser1.Visible = true; diff --git a/Source/RaUI/Properties/AssemblyInfo.cs b/Source/RaUI/Properties/AssemblyInfo.cs index 5263c98..df3674a 100644 --- a/Source/RaUI/Properties/AssemblyInfo.cs +++ b/Source/RaUI/Properties/AssemblyInfo.cs @@ -33,5 +33,5 @@ using System.Runtime.InteropServices; //可以指定所有这些值,也可以使用“生成号”和“修订号”的默认值 //通过使用 "*",如下所示: // [assembly: AssemblyVersion("1.0.*")] -[assembly: AssemblyVersion("4.0.2506.2701")] -[assembly: AssemblyFileVersion("4.0.2506.2701")] \ No newline at end of file +[assembly: AssemblyVersion("4.0.2508.1601")] +[assembly: AssemblyFileVersion("4.0.2508.1601")] \ No newline at end of file diff --git a/Source/RaUI/RaUIV4.csproj.user b/Source/RaUI/RaUIV4.csproj.user index 9b86104..bcb94c6 100644 --- a/Source/RaUI/RaUIV4.csproj.user +++ b/Source/RaUI/RaUIV4.csproj.user @@ -1,6 +1,9 @@ - + ShowAllFiles + + true + \ No newline at end of file diff --git a/Source/RaUI/UI/Controls/ButtonEX.cs b/Source/RaUI/UI/Controls/ButtonEX.cs index bc587fc..8b2c8b0 100644 --- a/Source/RaUI/UI/Controls/ButtonEX.cs +++ b/Source/RaUI/UI/Controls/ButtonEX.cs @@ -401,7 +401,9 @@ namespace ryControls { imageRect = Rectangle.Empty; textRect = Rectangle.Empty; - SizeF textSize = g.MeasureString(Text, Font); + var DD= GetTextFormatFlags(TextAlign, RightToLeft == RightToLeft.Yes); + SizeF textSize = TextRenderer.MeasureText(g, Text, Font, this.Size, DD); + //SizeF textSize =ControlPaint. g.MeasureString(Text, Font); if (Image == null) { switch (TextAlign) diff --git a/Source/RaUI/UI/Controls/ComboBox/ComboBoxEx2.cs b/Source/RaUI/UI/Controls/ComboBox/ComboBoxEx2.cs index 7ed7a85..d400931 100644 --- a/Source/RaUI/UI/Controls/ComboBox/ComboBoxEx2.cs +++ b/Source/RaUI/UI/Controls/ComboBox/ComboBoxEx2.cs @@ -118,23 +118,15 @@ namespace ryControls toolTip1.SetToolTip(BtnPopup, value); } } - private Font _font = new Font("宋体",9); /// - /// 字体 + /// /// - public override Font Font + /// + protected override void OnFontChanged(EventArgs e) { - get - { - return _font; - } - - set - { - _font = value; - txtSearch.Font = value; - BtnPopup.Font = value; - } + txtSearch.Font = base.Font; + BtnPopup.Font = base.Font; + base.OnFontChanged(e); } private bool _UseDefSkin = true; /// @@ -335,7 +327,9 @@ namespace ryControls } txtSearch.Focus(); subForm = new FrmComboBoxPopup(); - if(MaxPopupWidth>0) + subForm.Font = this.Font; + //subForm.ListBox. + if (MaxPopupWidth>0) { subForm.Width= MaxPopupWidth; } @@ -568,6 +562,14 @@ namespace ryControls /// public string ValueStr1 { get; set; } = ""; /// + /// int值1 + /// + public int ValueInt1 { get; set; } = 0; + /// + /// long值1 + /// + public long ValueLong1 { get; set; } = 0; + /// /// Tag /// public object Tag { get; set; } =null; diff --git a/Source/RaUI/UI/Controls/ComboBox/FrmComboBoxPopup.Designer.cs b/Source/RaUI/UI/Controls/ComboBox/FrmComboBoxPopup.Designer.cs index 5711937..8f5f1fc 100644 --- a/Source/RaUI/UI/Controls/ComboBox/FrmComboBoxPopup.Designer.cs +++ b/Source/RaUI/UI/Controls/ComboBox/FrmComboBoxPopup.Designer.cs @@ -32,11 +32,14 @@ // // FrmComboBoxPopup // - this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 12F); + this.AutoScaleDimensions = new System.Drawing.SizeF(7F, 14F); this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; - this.ClientSize = new System.Drawing.Size(464, 426); + this.ClientSize = new System.Drawing.Size(541, 497); + this.Font = new System.Drawing.Font("Consolas", 9F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(0))); + this.Margin = new System.Windows.Forms.Padding(4, 4, 4, 4); this.Name = "FrmComboBoxPopup"; this.ShowIcon = false; + this.Load += new System.EventHandler(this.FrmComboBoxPopup_Load); this.PreviewKeyDown += new System.Windows.Forms.PreviewKeyDownEventHandler(this.FrmComboBoxPopup_PreviewKeyDown); this.ResumeLayout(false); diff --git a/Source/RaUI/UI/Controls/ComboBox/FrmComboBoxPopup.cs b/Source/RaUI/UI/Controls/ComboBox/FrmComboBoxPopup.cs index 1106e4a..225dd53 100644 --- a/Source/RaUI/UI/Controls/ComboBox/FrmComboBoxPopup.cs +++ b/Source/RaUI/UI/Controls/ComboBox/FrmComboBoxPopup.cs @@ -36,7 +36,7 @@ namespace RaUI.UI.Controls.ComboBox /// /// /// - internal ListBoxEx ListBox=new ListBoxEx(); + public ListBoxEx ListBox=new(); /// /// /// @@ -45,6 +45,7 @@ namespace RaUI.UI.Controls.ComboBox InitializeComponent(); //RyForm.SetChildStyle(this); //this.Selectable = false; + ListBox.Font = this.Font; ListBox.ItemHeight = 30; ListBox.Parent = this; ListBox.Dock = DockStyle.Fill; @@ -117,5 +118,10 @@ namespace RaUI.UI.Controls.ComboBox { } + + private void FrmComboBoxPopup_Load(object sender, EventArgs e) + { + + } } } diff --git a/Source/RaUI/UI/Controls/ComboBox/ryComboBox.cs b/Source/RaUI/UI/Controls/ComboBox/ryComboBox.cs index 40fcd32..00034d0 100644 --- a/Source/RaUI/UI/Controls/ComboBox/ryComboBox.cs +++ b/Source/RaUI/UI/Controls/ComboBox/ryComboBox.cs @@ -5,6 +5,7 @@ using System.Drawing; using System.Windows.Forms; using ryControls; using System.Globalization; +using System.Drawing.Drawing2D; namespace ryControls { @@ -16,10 +17,14 @@ namespace ryControls { private List mUndoList = new List(); private Stack mRedoStack = new Stack(); - private bool mIsUndo = false; private UndoRedoInfo mLastInfo = new UndoRedoInfo("", 0); - private System.ComponentModel.IContainer components; private int mMaxUndoRedoSteps = 50; + //导入API函数 + [System.Runtime.InteropServices.DllImport("user32.dll ")] + static extern IntPtr GetWindowDC(IntPtr hWnd);//返回hWnd参数所指定的窗口的设备环境。 + + [System.Runtime.InteropServices.DllImport("user32.dll ")] + static extern int ReleaseDC(IntPtr hWnd, IntPtr hDC); //函数释放设备上下文环境(DC) private class UndoRedoInfo { public UndoRedoInfo(string text, int cursorLoc) @@ -67,7 +72,6 @@ namespace ryControls { if (!CanUndo) return; - mIsUndo = true; mRedoStack.Push(new UndoRedoInfo(Text, SelectionStart)); UndoRedoInfo info = (UndoRedoInfo)mUndoList[0]; mUndoList.RemoveAt(0); @@ -75,7 +79,6 @@ namespace ryControls SelectionStart = info.CursorLocation; //txtInfo.ScrollToCaret(); mLastInfo = info; - mIsUndo = false; } /// /// 重复操作 @@ -84,14 +87,12 @@ namespace ryControls { if (!CanRedo) return; - mIsUndo = true; mUndoList.Insert(0, new UndoRedoInfo(Text, SelectionStart)); LimitUndo(); UndoRedoInfo info = (UndoRedoInfo)mRedoStack.Pop(); Text = info.Text; SelectionStart = info.CursorLocation; //this.ScrollToCaret(); - mIsUndo = false; } private void LimitUndo() { @@ -109,36 +110,66 @@ namespace ryControls base.DoubleBuffered = true; base.FlatStyle = FlatStyle.Flat; base.DrawMode = DrawMode.OwnerDrawFixed; + base.DrawItem += new DrawItemEventHandler(delegate (object sender, DrawItemEventArgs e) { - if (e.Index < 0) + if (e.Index < 0) { return; } + //鼠标选中在这个项上 + if ((e.State & DrawItemState.Selected) != 0) { - return; - } - //StringFormat stringFormat = new StringFormat - //{ - // LineAlignment = StringAlignment.Center - //}; - e.DrawBackground(); - e.DrawFocusRectangle(); - if (base.Items[e.Index] is ComboPopupItem item) - { - var r = e.Bounds; - if (item.Image != null) - { - int width = item.Image.Width * 20 / item.Image.Height; - e.Graphics.DrawImage(item.Image, r.X + 2, r.Y + (r.Height - 20) / 2, width, 20); - //e.Graphics.DrawImage(engine.Icon,e.Bounds.Location); - r.Offset(width+2, 0); - } - e.Graphics.DrawString(item.Text, e.Font, new SolidBrush(e.ForeColor), r, StringFormat.GenericDefault); + //渐变画刷 + LinearGradientBrush brush = new LinearGradientBrush(e.Bounds, Color.FromArgb(255, 251, 237), + Color.FromArgb(255, 236, 181), LinearGradientMode.Vertical); + //填充区域 + Rectangle borderRect = new Rectangle(3, e.Bounds.Y, e.Bounds.Width - 5, e.Bounds.Height-2); + + e.Graphics.FillRectangle(brush, borderRect); + //画边框 + Pen pen = new Pen(Color.FromArgb(229, 195, 101)); + e.Graphics.DrawRectangle(pen, borderRect); } else { - SizeF size = e.Graphics.MeasureString(base.Items[e.Index].ToString(), e.Font); - float kk = e.Bounds.Y + (e.Bounds.Height - (int)size.Height); - e.Graphics.DrawString(base.Items[e.Index].ToString(), e.Font, new SolidBrush(e.ForeColor), e.Bounds.X, kk); + SolidBrush brush = new SolidBrush(Color.FromArgb(255, 255, 255)); + e.Graphics.FillRectangle(brush, e.Bounds); } + Rectangle textRect = new Rectangle(3, e.Bounds.Y + 1, e.Bounds.Width-5, e.Bounds.Height - 2); + switch (this.Items[e.Index]) + { + case clsCbbItem item: + Image img = item.Img; + //图片绘制的区域 + Rectangle imgRect = new Rectangle(6, e.Bounds.Y + 3, 16, 16); + e.Graphics.SmoothingMode = SmoothingMode.HighQuality; + e.Graphics.CompositingQuality = CompositingQuality.HighQuality; + e.Graphics.InterpolationMode = InterpolationMode.NearestNeighbor; + e.Graphics.PixelOffsetMode = System.Drawing.Drawing2D.PixelOffsetMode.Half; + e.Graphics.DrawImage(img, imgRect); + //文本内容显示区域 + textRect = new Rectangle(imgRect.Right + 2, imgRect.Y, e.Bounds.Width - imgRect.Width, e.Bounds.Height - 2); + break; + case ComboPopupItem item2: + Image img2 = item2.Image; + //图片绘制的区域 + Rectangle imgRect2 = new Rectangle(6, e.Bounds.Y + 3, 16, 16); + e.Graphics.SmoothingMode = SmoothingMode.HighQuality; + e.Graphics.CompositingQuality = CompositingQuality.HighQuality; + e.Graphics.InterpolationMode = InterpolationMode.NearestNeighbor; + e.Graphics.PixelOffsetMode = System.Drawing.Drawing2D.PixelOffsetMode.Half; + e.Graphics.DrawImage(img2, imgRect2); + //文本内容显示区域 + textRect = new Rectangle(imgRect2.Right + 2, imgRect2.Y, e.Bounds.Width - imgRect2.Width, e.Bounds.Height - 2); + break; + } + //获得项文本内容,绘制文本 + string itemText = this.Items[e.Index].ToString(); + + //文本格式垂直居中 + StringFormat strFormat = new StringFormat() + { + LineAlignment = StringAlignment.Center + }; + e.Graphics.DrawString(itemText, new Font("微软雅黑", 11), Brushes.Black, textRect, strFormat); }); } @@ -148,17 +179,26 @@ namespace ryControls /// 消息 protected override void WndProc(ref Message m) { + base.WndProc(ref m); if (m.Msg == 0xf || m.Msg == 0x133) { - ryControls.SkinHelp.ResetBorderColor(m, this, 1, Color.FromArgb(213, 216, 223)); - } - base.WndProc(ref m); - } + IntPtr hDC = GetWindowDC(m.HWnd); + if (hDC.ToInt32() == 0) //如果取设备上下文失败则返回 + { + return; + } - private void InitializeComponent() - { - this.SuspendLayout(); - this.ResumeLayout(false); + //建立Graphics对像 + Graphics g = Graphics.FromHdc(hDC); + //画边框的 + ControlPaint.DrawBorder(g, new Rectangle(0, 0, Width, Height), SkinHelp.DefalutBorderColor, ButtonBorderStyle.Solid); + //画坚线 + //ControlPaint.DrawBorder(g, new Rectangle(Width - Height, 0, Height, Height), Color.Red, ButtonBorderStyle.Solid); + //g.DrawLine(new Pen(Brushes.Blue, 2), new PointF(this.Width - this.Height, 0), new PointF(this.Width - this.Height, this.Height)); + //释放DC + ReleaseDC(m.HWnd, hDC); + return; + } } } diff --git a/Source/RaUI/UI/Controls/Hotkey/HotkeyTextBox.Designer.cs b/Source/RaUI/UI/Controls/Hotkey/HotkeyTextBox.Designer.cs index 9ac80db..1ef5114 100644 --- a/Source/RaUI/UI/Controls/Hotkey/HotkeyTextBox.Designer.cs +++ b/Source/RaUI/UI/Controls/Hotkey/HotkeyTextBox.Designer.cs @@ -28,46 +28,18 @@ /// private void InitializeComponent() { - this.BtnClear = new System.Windows.Forms.Button(); - this.TxtHotKey = new System.Windows.Forms.TextBox(); this.SuspendLayout(); // - // BtnClear + // HotkeyTextBox // - this.BtnClear.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right))); - this.BtnClear.Location = new System.Drawing.Point(245, 0); - this.BtnClear.Name = "BtnClear"; - this.BtnClear.Size = new System.Drawing.Size(43, 35); - this.BtnClear.TabIndex = 1; - this.BtnClear.Text = "X"; - this.BtnClear.UseVisualStyleBackColor = true; - this.BtnClear.Click += new System.EventHandler(this.BtnClear_Click); - // - // TxtHotKey - // - this.TxtHotKey.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left) - | System.Windows.Forms.AnchorStyles.Right))); - this.TxtHotKey.BorderStyle = System.Windows.Forms.BorderStyle.None; - this.TxtHotKey.Font = new System.Drawing.Font("宋体", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134))); - this.TxtHotKey.Location = new System.Drawing.Point(3, 8); - this.TxtHotKey.Name = "TxtHotKey"; - this.TxtHotKey.Size = new System.Drawing.Size(236, 19); - this.TxtHotKey.TabIndex = 2; - // - // ctlHotkey - // - this.Controls.Add(this.TxtHotKey); - this.Controls.Add(this.BtnClear); - this.Name = "ctlHotkey"; + this.DoubleBuffered = true; + this.Name = "HotkeyTextBox"; this.Size = new System.Drawing.Size(288, 35); this.Paint += new System.Windows.Forms.PaintEventHandler(this.CtlHotkey_Paint); this.ResumeLayout(false); - this.PerformLayout(); } #endregion - private System.Windows.Forms.Button BtnClear; - private System.Windows.Forms.TextBox TxtHotKey; } } diff --git a/Source/RaUI/UI/Controls/Hotkey/HotkeyTextBox.cs b/Source/RaUI/UI/Controls/Hotkey/HotkeyTextBox.cs index c8df2ca..9abe59c 100644 --- a/Source/RaUI/UI/Controls/Hotkey/HotkeyTextBox.cs +++ b/Source/RaUI/UI/Controls/Hotkey/HotkeyTextBox.cs @@ -26,15 +26,160 @@ namespace ryControls InitializeComponent(); //定义KeyPress事件 //base.KeyPress += delegate(object sender, KeyPressEventArgs e) { e.Handled = true; }; - TxtHotKey.ReadOnly = true; - TxtHotKey.BackColor = Color.White; - TxtHotKey.KeyDown += TxtHotKey_KeyDown; - TxtHotKey.KeyUp += TxtHotKey_KeyUp; - TxtHotKey.Top = (Height - TxtHotKey.Height) / 2; //Application.AddMessageFilter(this); base.BackColor = Color.White; } /// + /// 清除按钮位置 + /// + public Rectangle ClearBtnRect + { + get + { + return new Rectangle(this.Width - this.Height-1, 1, Height-1, Height-2); + } + } + /// + /// 热键文本位置 + /// + public Rectangle HotKeyTextRect + { + get + { + return new Rectangle(0, 0, this.Width -this.Height-2, Height); + } + } + /// + /// + /// + /// + protected override void OnMouseDown(MouseEventArgs e) + { + if(ClearBtnRect.Contains(e.Location)) + { + m_Modifiers = Keys.None; + m_Key = Keys.None; + UpdateText(); + } + base.OnMouseDown(e); + } + private ControlState _controlState;//控件状态 + internal ControlState ControlState //控件的状态 + { + get { return _controlState; } + set + { + if (_controlState != value) + { + _controlState = value; + base.Invalidate(); + } + } + } + private ControlState _ClearBtnState;//控件状态 + internal ControlState ClearBtnState //控件的状态 + { + get { return _ClearBtnState; } + set + { + if (_ClearBtnState != value) + { + _ClearBtnState = value; + base.Invalidate(); + } + } + } + /// + /// + /// + /// + protected override void OnMouseUp(MouseEventArgs e) + { + base.OnMouseUp(e); + if (e.Button == MouseButtons.Left && e.Clicks == 1) + { + if (ClientRectangle.Contains(e.Location))//控件区域包含鼠标的位置 + { + ControlState = ControlState.Hover; + } + else + { + ControlState = ControlState.Normal; + } + } + } + /// + /// + /// + /// + protected override void OnMouseLeave(EventArgs e) + { + ControlState = ControlState.Normal; + ClearBtnState= ControlState.Normal; + base.OnMouseLeave(e); + } + /// + /// + /// + /// + protected override void OnLostFocus(EventArgs e) + { + ControlState = ControlState.Normal; + ClearBtnState = ControlState.Normal; + base.OnLostFocus(e); + } + /// + /// + /// + /// + protected override void OnMouseMove(MouseEventArgs e) + { + if(ClearBtnRect.Contains(e.Location)) + { + if (ClearBtnState != ControlState.Hover) + { + ClearBtnState = ControlState.Hover; + this.Invalidate(); + } + } + else + { + if (ClearBtnState == ControlState.Hover) + { + ClearBtnState = ControlState.Normal; + this.Invalidate(); + } + } + base.OnMouseMove(e); + } + /// + /// + /// + /// + protected override void OnPaint(PaintEventArgs e) + { + e.Graphics.TextRenderingHint = System.Drawing.Text.TextRenderingHint.ClearTypeGridFit; + e.Graphics.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.AntiAlias; + e.Graphics.CompositingQuality = System.Drawing.Drawing2D.CompositingQuality.HighQuality; + e.Graphics.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.HighQualityBicubic; + StringFormat sf = new StringFormat(); + sf.Trimming = StringTrimming.EllipsisCharacter; + sf.FormatFlags = StringFormatFlags.NoWrap; + sf.LineAlignment = StringAlignment.Center; + sf.Alignment = StringAlignment.Center; + Pen pen = new Pen(new SolidBrush(ClearBtnState== ControlState.Hover ? Color.FromArgb(43, 141, 225) : ForeColor), 1); + //var offset =this.Height/4; + //var btn_rect= ClearBtnRect; + e.Graphics.DrawPath(pen,MGdu.WinFormUI.MyGraphics.GraphicsPathHelper.CreateCloseFlagPath(ClearBtnRect)); + //e.Graphics.DrawLine(pen, btn_rect.Left+ offset, btn_rect.Top+ offset, btn_rect.Right- offset, btn_rect.Bottom- offset); + //e.Graphics.DrawLine(pen, btn_rect.Right- offset, btn_rect.Top+ offset, btn_rect.Left+offset, btn_rect.Bottom- offset); + pen.Dispose(); + //e.Graphics.DrawString("X", MouseInClearBtn?new Font(Font.FontFamily,Font.Size+2, FontStyle.Bold): Font, new SolidBrush(MouseInClearBtn?Color.Blue: ForeColor), ClearBtnRect, sf); + sf.Alignment = StringAlignment.Near; + e.Graphics.DrawString(" "+tmpText, Font,new SolidBrush(ForeColor), HotKeyTextRect, sf); + ControlPaint.DrawBorder(e.Graphics, this.ClientRectangle, ControlState== ControlState.Hover?Color.FromArgb(43, 141, 225) : SkinHelp.DefalutBorderColor, ButtonBorderStyle.Solid); + } + /// /// /// ~HotkeyTextBox() @@ -61,19 +206,7 @@ namespace ryControls /// protected override void OnSizeChanged(EventArgs e) { - TxtHotKey.Top = (Height - TxtHotKey.Height) / 2; - TxtHotKey.Width = Width - BtnClear.Width - 2; - BtnClear.Top = 0; - BtnClear.Left = TxtHotKey.Left + TxtHotKey.Width; - BtnClear.Height = Height; - } - private void TxtHotKey_KeyDown(object sender, KeyEventArgs e) - { - OnKeyDown(e); - } - private void TxtHotKey_KeyUp(object sender, KeyEventArgs e) - { - OnKeyUp(e); + } //使文本属性失效掉 /// @@ -82,10 +215,11 @@ namespace ryControls [Description("此属性无效")] public new string Text { - get { return TxtHotKey.Text; } + get { return tmpText; } set { LoadHotKey(value); + this.Invalidate(); } } /// @@ -109,6 +243,37 @@ namespace ryControls T_Modifiers = item[0].ToInt(0); T_Key = (Keys)item[1].ToInt(0); } + else if(item.Length <=4) + { + var modifiers = "+"; + for (int i = 0; i < item.Length-1; i++) + { + modifiers += item[i] + "+"; + } + m_Modifiers = Keys.None; + if (modifiers.IndexOfEx("+ctrl+")>=0) + { + m_Modifiers |= Keys.Control; + } + if (modifiers.IndexOfEx("+alt+") >= 0) + { + m_Modifiers |= Keys.Alt; + } + if (modifiers.IndexOfEx("+shift+") >= 0) + { + m_Modifiers |= Keys.Shift; + } + if (modifiers.IndexOfEx("+win+") >= 0) + { + m_Modifiers |= Keys.LWin; + } + var keyString = item[item.Length - 1]; + if (Enum.TryParse(keyString, out Keys key)) + { + T_Key = key; + } + UpdateText(); + } } catch { @@ -119,10 +284,8 @@ namespace ryControls private void UpdateText() { HotkeyValue xvalue = new HotkeyValue(T_Modifiers, (int)T_Key); - base.Text = xvalue.ToString(); - TxtHotKey.Text = base.Text; - TxtHotKey.SelectionLength = 0; - TxtHotKey.SelectionStart = 0; + tmpText = xvalue.ToString(); + this.Invalidate(); } /// /// 保存热键 @@ -221,11 +384,11 @@ namespace ryControls } m_Modifiers = value.Modifiers; m_Key = value.KeyCode; - base.Text = value.ToString();//赋值 - TxtHotKey.Text = base.Text; + Text = value.ToString();//赋值 e.Handled = true; base.OnKeyDown(e); } + private string tmpText = ""; //TextBox的KeyDown事件 /// /// KeyDown事件 @@ -236,7 +399,7 @@ namespace ryControls if(m_Modifiers!=Keys.None && m_Key==Keys.None) { m_Modifiers = Keys.None; - TxtHotKey.Text = "错误的热键"; + tmpText = "错误的热键"; } e.Handled = false; base.OnKeyUp(e); @@ -250,7 +413,17 @@ namespace ryControls private void CtlHotkey_Paint(object sender, PaintEventArgs e) { - e.Graphics.DrawRectangle(new Pen(Color.FromArgb(213, 216, 223)), new Rectangle(0, 0, this.Width - 1, this.Height - 1)); + //e.Graphics.DrawRectangle(new Pen(Color.FromArgb(213, 216, 223)), new Rectangle(0, 0, this.Width - 1, this.Height - 1)); + } + + private void BtnClear_KeyDown(object sender, KeyEventArgs e) + { + OnKeyDown(e); + } + + private void BtnClear_KeyUp(object sender, KeyEventArgs e) + { + OnKeyUp(e); } } } diff --git a/Source/RaUI/UI/Controls/TextBoxEx2.cs b/Source/RaUI/UI/Controls/TextBoxEx2.cs index ac84edb..45f5b0b 100644 --- a/Source/RaUI/UI/Controls/TextBoxEx2.cs +++ b/Source/RaUI/UI/Controls/TextBoxEx2.cs @@ -92,6 +92,10 @@ namespace ryControls { e.Graphics.Clear(this.BackColor); } + else if(!base.Enabled) + { + e.Graphics.Clear(SystemColors.Control); + } e.Graphics.DrawRectangle(new Pen(SkinHelp.DefalutBorderColor), new Rectangle(0, 0, this.Width - 1, this.Height - 1)); if(txtInfo.Text.Length==0 && !txtInfo.Visible) { @@ -99,10 +103,17 @@ namespace ryControls Font font = this.Font; // 使用当前控件的字体。 Rectangle rect = this.ClientRectangle; // 在当前控件的客户区域绘制。 StringFormat stringFormat = new StringFormat(); - stringFormat.LineAlignment = StringAlignment.Center; + if (!Multiline) + { + stringFormat.LineAlignment = StringAlignment.Center; + } + else + { + rect.Offset(0, 6); + } using (Graphics g = this.CreateGraphics()) { - g.DrawString(" "+EmptyText, font, brush, rect, stringFormat); + g.DrawString(" " + EmptyText, font, brush, rect, stringFormat); } } } @@ -149,7 +160,7 @@ namespace ryControls public bool Multiline { get { return txtInfo.Multiline; } - set { txtInfo.Multiline = value; txtInfo.ScrollBars = System.Windows.Forms.ScrollBars.Vertical; } + set { txtInfo.Multiline = value; txtInfo.ScrollBars = System.Windows.Forms.ScrollBars.Vertical;this.Invalidate(); } } /// /// 是否在显示不下时换行 @@ -299,7 +310,6 @@ namespace ryControls private void TextBoxEx2_FontChanged(object sender, EventArgs e) { txtInfo.Font = this.Font; - } /// /// diff --git a/Source/RaUI/UI/HtmlRenderer/HtmlLabel.cs b/Source/RaUI/UI/HtmlRenderer/HtmlLabel.cs index b8a37d9..6ee8fb5 100644 --- a/Source/RaUI/UI/HtmlRenderer/HtmlLabel.cs +++ b/Source/RaUI/UI/HtmlRenderer/HtmlLabel.cs @@ -301,13 +301,13 @@ namespace TheArtOfDev.HtmlRenderer.WinForms } /// - /// Automatically sets the size of the label by content size + /// ݴСԶñǩĴС /// [Browsable(true)] [DefaultValue(true)] [EditorBrowsable(EditorBrowsableState.Always)] [DesignerSerializationVisibility(DesignerSerializationVisibility.Visible)] - [Description("Automatically sets the size of the label by content size.")] + [Description("ݴСԶñǩĴС ")] public override bool AutoSize { get { return base.AutoSize; } @@ -324,12 +324,12 @@ namespace TheArtOfDev.HtmlRenderer.WinForms } /// - /// Automatically sets the height of the label by content height (width is not effected). + /// ݸ߶Զñǩĸ߶ȣȲӰ죩 /// [Browsable(true)] [DefaultValue(false)] [Category("Layout")] - [Description("Automatically sets the height of the label by content height (width is not effected)")] + [Description("ݸ߶Զñǩĸ߶ȣȲӰ죩")] public virtual bool AutoSizeHeightOnly { get { return _autoSizeHight; } diff --git a/Source/RaUI/UI/ObjectListView/Rendering/Renderers.cs b/Source/RaUI/UI/ObjectListView/Rendering/Renderers.cs index 7f298cd..3c56ade 100644 --- a/Source/RaUI/UI/ObjectListView/Rendering/Renderers.cs +++ b/Source/RaUI/UI/ObjectListView/Rendering/Renderers.cs @@ -1,4 +1,4 @@ -/* +/* * Renderers - A collection of useful renderers that are used to owner draw a cell in an ObjectListView * * Author: Phillip Piper @@ -907,19 +907,23 @@ namespace BrightIdeasSoftware { { if (String.IsNullOrEmpty(txt)) return Size.Empty; - - if (this.UseGdiTextRendering) + try { - Size proposedSize = new Size(width, Int32.MaxValue); - return TextRenderer.MeasureText(g, txt, this.Font, proposedSize, NormalTextFormatFlags); - } - - // Using GDI+ renderering - using (StringFormat fmt = new StringFormat()) { - fmt.Trimming = StringTrimming.EllipsisCharacter; - SizeF sizeF = g.MeasureString(txt, this.Font, width, fmt); - return new Size(1 + (int)sizeF.Width, 1 + (int)sizeF.Height); + if (this.UseGdiTextRendering) + { + Size proposedSize = new Size(width, Int32.MaxValue); + return TextRenderer.MeasureText(g, txt, this.Font, proposedSize, NormalTextFormatFlags); + } + + // Using GDI+ renderering + using (StringFormat fmt = new StringFormat()) + { + fmt.Trimming = StringTrimming.EllipsisCharacter; + SizeF sizeF = g.MeasureString(txt, this.Font, width, fmt); + return new Size(1 + (int)sizeF.Width, 1 + (int)sizeF.Height); + } } + catch { return Size.Empty; } } /// @@ -1716,15 +1720,15 @@ namespace BrightIdeasSoftware { /// Bounds of the cell /// /// The string to be drawn - /// ˢ - public virtual int DrawText2(Graphics g, Rectangle r,int offset_x, String txt, Brush brush) + /// + public virtual int DrawText2(Graphics g, Rectangle r, int offset_x, String txt, Brush brush) { var txt_size = g.MeasureString(txt, Font).ToSize(); StringFormat sf = new StringFormat(); sf.Trimming = StringTrimming.EllipsisCharacter; - sf.FormatFlags = StringFormatFlags.NoWrap;//Զ - g.DrawString(txt, Font, brush,new RectangleF(r.Left+ offset_x, r.Top + 2 + (r.Height - txt_size.Height) / 2,r.Width- offset_x, r.Height),sf); - return txt_size.Width+1; + sf.FormatFlags = StringFormatFlags.NoWrap;//<2F>Զ + g.DrawString(txt, Font, brush, new RectangleF(r.Left + offset_x, r.Top + 2 + (r.Height - txt_size.Height) / 2, r.Width - offset_x, r.Height), sf); + return txt_size.Width + 1; } /// /// Draw the given text and optional image in the "normal" fashion @@ -1751,7 +1755,7 @@ namespace BrightIdeasSoftware { { var txt_size = g.MeasureString(txt, Font).ToSize(); var rect = new RectangleF(r.Left + offset_x, r.Top + 2 + (r.Height - txt_size.Height) / 2, r.Width - offset_x, r.Height); - var rect_back = new RectangleF(r.Left + offset_x, r.Top + 2, txt_size.Width, r.Height-4); + var rect_back = new RectangleF(r.Left + offset_x, r.Top + 2, txt_size.Width, r.Height - 4); g.FillRectangle(back_brush, rect_back); StringFormat sf = new StringFormat(); sf.Trimming = StringTrimming.EllipsisCharacter; @@ -1759,6 +1763,64 @@ namespace BrightIdeasSoftware { return txt_size.Width + 1; } /// + /// Draw the given text and optional image in the "normal" fashion + /// + /// Graphics context to use for drawing + /// Bounds of the cell + /// + /// The string to be drawn + /// 笔刷 + public virtual int DrawText2(Graphics g, Rectangle r,int offset_x, String txt, Color forecolor) + { + try + { + StringFormat sf = new StringFormat(); + sf.Trimming = StringTrimming.EllipsisCharacter; + + sf.FormatFlags = StringFormatFlags.NoWrap;//自动换行 + Size txt_size = TextRenderer.MeasureText(g, txt, Font, r.Size, TextFormatFlags.NoPadding | TextFormatFlags.PreserveGraphicsTranslateTransform); + TextRenderer.DrawText(g, txt, Font, new Rectangle(r.Left + offset_x, r.Top + 2 + (r.Height - txt_size.Height) / 2, r.Width - offset_x, r.Height), forecolor, TextFormatFlags.NoPadding | TextFormatFlags.PreserveGraphicsTranslateTransform); + //g.DrawString(txt, Font, br ush,new RectangleF(r.Left+ offset_x, r.Top + 2 + (r.Height - txt_size.Height) / 2,r.Width- offset_x, r.Height),sf); + return txt_size.Width; + } + catch { return 0; } + } + /// + /// Draw the given text and optional image in the "normal" fashion + /// + /// Graphics context to use for drawing + /// Bounds of the cell + /// + /// The string to be drawn + public virtual int DrawText3(Graphics g, Rectangle r, int offset_x, String txt) + { + return DrawText2(g, r, offset_x, txt, GetForegroundColor()); + } + /// + /// + /// + /// + /// 这里的r + /// + /// + /// + /// + /// + public virtual int DrawTextAndBackColor2(Graphics g, Rectangle r, int offset_x, string txt, Color forecolor, Color backcolor) + { + try + { + var txt_size = TextRenderer.MeasureText(g, txt, Font, r.Size, TextFormatFlags.NoPadding | TextFormatFlags.PreserveGraphicsTranslateTransform); + var rect = new Rectangle(r.Left + offset_x, r.Top + 2 + (r.Height - txt_size.Height) / 2, r.Width - offset_x, r.Height); + var rect_back = new Rectangle(r.Left + offset_x, r.Top + 2, txt_size.Width, r.Height - 4); + + g.FillRectangle(new SolidBrush(backcolor), rect_back); + TextRenderer.DrawText(g, txt, Font, rect, forecolor, TextFormatFlags.NoPadding | TextFormatFlags.PreserveGraphicsTranslateTransform); + return txt_size.Width; + } + catch { return 0; } + } + /// /// /// /// @@ -1771,7 +1833,7 @@ namespace BrightIdeasSoftware { { var width_bit = bitmap.Width * bit_height / bitmap.Height; g.DrawImage(bitmap, r.X+ offset_x, r.Y + (r.Height - bit_height) / 2, width_bit, bit_height); - return width_bit + 1; + return width_bit ; } /// /// Print the given text in the given rectangle using only GDI routines @@ -2887,10 +2949,10 @@ namespace BrightIdeasSoftware { #region Configuration Properties /// - /// ǷӦϵͳʽƣ + /// 此栏是否应以系统样式绘制? /// [Category("ObjectListView"), - Description("ǷӦϵͳʽ"), + Description("此栏是否应以系统样式绘制"), DefaultValue(true)] public bool UseStandardBar { get { return useStandardBar; } @@ -2900,10 +2962,10 @@ namespace BrightIdeasSoftware { private bool useStandardBar = true; /// - /// ǵĵԪ߿ʼƶصͼ + /// 将从我们的单元格边框开始绘制多少像素的条形图 /// [Category("ObjectListView"), - Description("ǵĵԪ߿ʼƶصͼ"), + Description("将从我们的单元格边框开始绘制多少像素的条形图"), DefaultValue(2)] public int Padding { get { return padding; } @@ -2913,10 +2975,10 @@ namespace BrightIdeasSoftware { private int padding = 2; /// - ///ڻƽ֮ǰʹʲôɫؼڲ + ///在绘制进度条之前,将使用什么颜色填充控件内部? /// [Category("ObjectListView"), - Description("ͼڲɫ"), + Description("条形图内部的颜色"), DefaultValue(typeof (Color), "AliceBlue")] public Color BackgroundColor { get { return backgroundColor; } @@ -2926,10 +2988,10 @@ namespace BrightIdeasSoftware { private Color backgroundColor = Color.AliceBlue; /// - /// ߿ɫ + /// 进度条边框颜色 /// [Category("ObjectListView"), - Description("߿ɫ"), + Description("进度条边框颜色"), DefaultValue(typeof (Color), "Black")] public Color FrameColor { get { return frameColor; } @@ -2939,10 +3001,10 @@ namespace BrightIdeasSoftware { private Color frameColor = Color.Black; /// - /// ı߿ؿ + /// 进度条的边框像素宽 /// [Category("ObjectListView"), - Description("ı߿ؿ"), + Description("进度条的边框像素宽"), DefaultValue(1.0f)] public float FrameWidth { get { return frameWidth; } @@ -2952,11 +3014,11 @@ namespace BrightIdeasSoftware { private float frameWidth = 1.0f; /// - /// ġ䡱Ӧʲôɫ + /// 进度条的“填充”部分应该是什么颜色? /// - /// GradientStartColorΪColor.Emptyʱʹôѡ + /// 仅当GradientStartColor为Color.Empty时才使用此选项 [Category("ObjectListView"), - Description("ġ䡱Ӧʲôɫ"), + Description("进度条的“填充”部分应该是什么颜色?"), DefaultValue(typeof (Color), "BlueViolet")] public Color FillColor { get { return fillColor; } @@ -2965,11 +3027,11 @@ namespace BrightIdeasSoftware { private Color fillColor = Color.BlueViolet; /// - /// ǷʾıٷֱȽʾ + /// 进度条中是否显示文本百分比进度显示 /// /// [Category("ObjectListView"), - Description("ǷʾıٷֱȽʾ"), + Description("进度条中是否显示文本百分比进度显示"), DefaultValue(typeof(Boolean), "True")] public bool ShowTextPercent { @@ -2979,10 +3041,10 @@ namespace BrightIdeasSoftware { private bool showTextPercent = true; /// - /// ʹýԴɫʼ + /// 使用渐变以此颜色开始填充进度条 /// [Category("ObjectListView"), - Description("ʹýԴɫʼ"), + Description("使用渐变以此颜色开始填充进度条"), DefaultValue(typeof (Color), "CornflowerBlue")] public Color GradientStartColor { get { return startColor; } @@ -2992,10 +3054,10 @@ namespace BrightIdeasSoftware { private Color startColor = Color.CornflowerBlue; /// - /// ʹýԴɫβĽ + /// 使用渐变填充以此颜色结尾的进度条 /// [Category("ObjectListView"), - Description("ʹýԴɫβĽ"), + Description("使用渐变填充以此颜色结尾的进度条"), DefaultValue(typeof (Color), "DarkBlue")] public Color GradientEndColor { get { return endColor; } @@ -3003,10 +3065,10 @@ namespace BrightIdeasSoftware { } private Color endColor = Color.DarkBlue; /// - /// ʹýԴɫʼ佥 + /// 使用渐变以此颜色开始填充渐满进度条 /// [Category("ObjectListView"), - Description("ʹýԴɫʼ佥"), + Description("使用渐变以此颜色开始填充渐满进度条"), DefaultValue(typeof(Color), "CornflowerBlue")] public Color NearGradientStartColor { @@ -3017,10 +3079,10 @@ namespace BrightIdeasSoftware { private Color near_startColor = Color.CornflowerBlue; /// - /// ʹýԴɫβĽ + /// 使用渐变填充以此颜色结尾的渐满进度条 /// [Category("ObjectListView"), - Description("ʹýԴɫβĽ"), + Description("使用渐变填充以此颜色结尾的渐满进度条"), DefaultValue(typeof(Color), "DarkBlue")] public Color NearGradientEndColor { @@ -3030,10 +3092,10 @@ namespace BrightIdeasSoftware { private Color near_endColor = Color.DarkBlue; /// - /// бö + /// 无论列变得多宽,进度条都不会比这个宽。 /// [Category("Behavior"), - Description("Զ"), + Description("进度条永远不会比这个更宽"), DefaultValue(100)] public int MaximumWidth { get { return maximumWidth; } @@ -3043,10 +3105,10 @@ namespace BrightIdeasSoftware { private int maximumWidth = 100; /// - /// ۵Ԫжߣ + /// 无论单元格有多高,进度条都不会比这个高 /// [Category("Behavior"), - Description("Զ"), + Description("进度条永远不会比这个高"), DefaultValue(16)] public int MaximumHeight { get { return maximumHeight; } @@ -3056,10 +3118,10 @@ namespace BrightIdeasSoftware { private int maximumHeight = 16; /// - /// ԤڵСֵСڴֵֵʾһ + /// 预期的最小数据值。小于此值的值将显示一个空条。 /// [Category("Behavior"), - Description("ԤڵСֵСڴֵֵʾһ"), + Description("预期的最小数据值。小于此值的值将显示一个空条。"), DefaultValue(0.0)] public double MinimumValue { get { return minimumValue; } @@ -3068,10 +3130,10 @@ namespace BrightIdeasSoftware { private double minimumValue = 0.0; /// - /// ӽʱֵ,ڸֵʱʾͬɫСڵMinimumValueMaximumValueֵʾδøֵ + /// 接近满时的值,高于该值时,显示不同颜色,小于等于MinimumValue或大于MaximumValue值,则表示未设置该值 /// [Category("Behavior"), - Description("ӽʱֵ,ڸֵʱʾͬɫСڵMinimumValueMaximumValueֵʾδøֵ"), + Description("接近满时的值,高于该值时,显示不同颜色,小于等于MinimumValue或大于MaximumValue值,则表示未设置该值"), DefaultValue(0.0)] public double NearFullValue { @@ -3081,10 +3143,10 @@ namespace BrightIdeasSoftware { private double nearfullValue = 0.0; /// - ///ΧֵڴֵֵһΡ + ///范围的最大值。大于此值的值将给出一个完整的条形。 /// [Category("Behavior"), - Description("ΧֵڴֵֵһΡ"), + Description("范围的最大值。大于此值的值将给出一个完整的条形。"), DefaultValue(100.0)] public double MaximumValue { get { return maximumValue; } @@ -3674,10 +3736,10 @@ namespace BrightIdeasSoftware { } private int imageTextSpace = 4; /// - /// + /// 顶部留白像素 /// [Category("ObjectListView"), - Description(""), + Description("顶部留白像素"), DefaultValue(4)] public int TopSpace { @@ -3870,11 +3932,11 @@ namespace BrightIdeasSoftware { private OLVColumn.ButtonSizingMode sizingMode = OLVColumn.ButtonSizingMode.CellBounds; /// - /// ȡSizingModeΪFixedBoundsʱťĴС + /// 获取或设置SizingMode为FixedBounds时按钮的大小 /// /// If this is not set, the bounds of the cell will be used [Category("ObjectListView"), - Description("SizingModeΪFixedBoundsʱťĴС"), + Description("SizingMode为FixedBounds时按钮的大小"), DefaultValue(null)] public Size? ButtonSize { @@ -3884,10 +3946,10 @@ namespace BrightIdeasSoftware { private Size? buttonSize; /// - /// ȡSizingModeΪTextBoundsʱԪΧĶռ + /// 获取或设置SizingMode为TextBounds时单元格周围的额外空间 /// [Category("ObjectListView"), - Description("SizingModeΪTextBoundsʱΧƵԪĶռ")] + Description("SizingMode为TextBounds时围绕单元格的额外空间")] public Size? ButtonPadding { get { return this.buttonPadding; } @@ -3928,50 +3990,50 @@ namespace BrightIdeasSoftware { } private int minButtonWidth = -1; /// - ///ȡôаťɫ(аťĻ) + ///获取或设置此列按钮的字体颜色(如果有按钮的话) /// [Category("ObjectListView"), - Description("ȡôаťɫ(аťĻ)")] + Description("获取或设置此列按钮的字体颜色(如果有按钮的话)")] public Color ButtonForeColor { get; set; } = Color.White; /// - ///ȡôаťıɫ(аťĻ) + ///获取或设置此列按钮的背景颜色(如果有按钮的话) /// [Category("ObjectListView"), - Description("ȡôаťıɫ(аťĻ)")] + Description("获取或设置此列按钮的背景颜色(如果有按钮的话)")] public Color ButtonBaseColor { get; set; } = Color.Green; /// - ///ȡôаťı߿ɫ(аťĻ) + ///获取或设置此列按钮的边框颜色(如果有按钮的话) /// [Category("ObjectListView"), - Description("ȡôаťı߿ɫ(аťĻ)")] + Description("获取或设置此列按钮的边框颜色(如果有按钮的话)")] public Color ButtonBorderColor { get; set; } = Color.Gray; /// - ///ȡôаťڱ߿ɫ(аťĻ) + ///获取或设置此列按钮的内边框颜色(如果有按钮的话) /// [Category("ObjectListView"), - Description("ȡôаťڱ߿ɫ(аťĻ)")] + Description("获取或设置此列按钮的内边框颜色(如果有按钮的话)")] public Color ButtonInnerBorderColor { get; set; } = Color.Gray; /// - ///ȡôаťǷ񻭱߿(аťĻ) + ///获取或设置此列按钮是否画边框(如果有按钮的话) /// [Category("ObjectListView"), - Description("ȡôаťǷ񻭱߿(аťĻ)")] + Description("获取或设置此列按钮是否画边框(如果有按钮的话)")] public bool ButtonDrawBorder { get; diff --git a/Source/RaUI/UI/Rili/PaDateInput.cs b/Source/RaUI/UI/Rili/PaDateInput.cs index 7185a99..b2bcd81 100644 --- a/Source/RaUI/UI/Rili/PaDateInput.cs +++ b/Source/RaUI/UI/Rili/PaDateInput.cs @@ -214,7 +214,6 @@ namespace RaUI.UI.Rili this.Invalidate(); base.OnMouseDown(e); } - int index = 0; /// /// /// diff --git a/Source/RaUI/UI/Scintilla.NET/Highlight/AutoComplete/ScintillaWrapper.cs b/Source/RaUI/UI/Scintilla.NET/Highlight/AutoComplete/ScintillaWrapper.cs index 3a0fb24..ae5ced6 100644 --- a/Source/RaUI/UI/Scintilla.NET/Highlight/AutoComplete/ScintillaWrapper.cs +++ b/Source/RaUI/UI/Scintilla.NET/Highlight/AutoComplete/ScintillaWrapper.cs @@ -3,128 +3,131 @@ using System.Drawing; using System.Windows.Forms; using ScintillaNETV2; using ScintillaNETV2.AutocompleteMenuNS; -/// -/// -/// -public class ScintillaWrapper : ITextBoxWrapper +namespace ScintillaNETV2.AutocompleteMenuNS { /// /// /// - public ScintillaNETV2.Scintilla target; - /// - /// - /// - /// - public ScintillaWrapper(ScintillaNETV2.Scintilla trgt) + public class ScintillaWrapper : ITextBoxWrapper { - target = trgt; - - //Now add handler for the UpdateUI event. - target.UpdateUI += (sender, args) => + /// + /// + /// + public ScintillaNETV2.Scintilla target; + /// + /// + /// + /// + public ScintillaWrapper(ScintillaNETV2.Scintilla trgt) { - if (args?.Change == UpdateChange.HScroll || args?.Change == UpdateChange.VScroll) + target = trgt; + + //Now add handler for the UpdateUI event. + target.UpdateUI += (sender, args) => { - Scroll?.Invoke(sender, new ScrollEventArgs(ScrollEventType.LargeIncrement, 0)); - } - }; - } - - /// - /// - /// - public bool Readonly - { - get{ return target.ReadOnly; } - } - /// - /// - /// - public string SelectedText - { - get { return target.SelectedText; } - set - { - //Store the start of the selection. - int start = target.SelectionStart; - - //Delete the current text between selections. - target.DeleteRange(target.SelectionStart, (target.SelectionEnd - target.SelectionStart)); - - //Add the text in the same postion. - target.InsertText(start, value); - - //Clear selection and make sure the caret is at the end. - target.SelectionStart = (start + value.Length); - target.SelectionEnd = (start + value.Length); + if (args?.Change == UpdateChange.HScroll || args?.Change == UpdateChange.VScroll) + { + Scroll?.Invoke(sender, new ScrollEventArgs(ScrollEventType.LargeIncrement, 0)); + } + }; } - } - /// - /// - /// - public int SelectionLength - { - get { return (target.SelectionEnd - target.SelectionStart); } - set { target.SelectionEnd = (target.SelectionStart + value); } - } - /// - /// - /// - public int SelectionStart - { - get { return target.SelectionStart; } - set { target.SelectionStart = value; } - } - /// - /// - /// - public Control TargetControl - { - get { return target; } - } - /// - /// - /// - public string Text - { - get { return target.Text; } - } - /// - /// - /// - /// - /// - public Point GetPositionFromCharIndex(int pos) - { - return new Point(target.PointXFromPosition(pos), target.PointYFromPosition(pos)); - } - /// - /// - /// - public virtual event KeyEventHandler KeyDown - { - add { target.KeyDown += value; } - remove { target.KeyDown -= value; } + /// + /// + /// + public bool Readonly + { + get { return target.ReadOnly; } + } + /// + /// + /// + public string SelectedText + { + get { return target.SelectedText; } + set + { + //Store the start of the selection. + int start = target.SelectionStart; + + //Delete the current text between selections. + target.DeleteRange(target.SelectionStart, (target.SelectionEnd - target.SelectionStart)); + + //Add the text in the same postion. + target.InsertText(start, value); + + //Clear selection and make sure the caret is at the end. + target.SelectionStart = (start + value.Length); + target.SelectionEnd = (start + value.Length); + } + } + /// + /// + /// + public int SelectionLength + { + get { return (target.SelectionEnd - target.SelectionStart); } + set { target.SelectionEnd = (target.SelectionStart + value); } + } + /// + /// + /// + public int SelectionStart + { + get { return target.SelectionStart; } + set { target.SelectionStart = value; } + } + /// + /// + /// + public Control TargetControl + { + get { return target; } + } + /// + /// + /// + public string Text + { + get { return target.Text; } + } + /// + /// + /// + /// + /// + public Point GetPositionFromCharIndex(int pos) + { + return new Point(target.PointXFromPosition(pos), target.PointYFromPosition(pos)); + } + + /// + /// + /// + public virtual event KeyEventHandler KeyDown + { + add { target.KeyDown += value; } + remove { target.KeyDown -= value; } + } + /// + /// + /// + public virtual event EventHandler LostFocus + { + add { target.LostFocus += value; } + remove { target.LostFocus -= value; } + } + /// + /// + /// + public virtual event MouseEventHandler MouseDown + { + add { target.MouseDown += value; } + remove { target.MouseDown -= value; } + } + /// + /// + /// + public event ScrollEventHandler Scroll; } - /// - /// - /// - public virtual event EventHandler LostFocus - { - add { target.LostFocus += value; } - remove { target.LostFocus -= value; } - } - /// - /// - /// - public virtual event MouseEventHandler MouseDown - { - add { target.MouseDown += value; } - remove { target.MouseDown -= value; } - } - /// - /// - /// - public event ScrollEventHandler Scroll; } \ No newline at end of file diff --git a/Source/RaUI/UI/Scintilla.NET/Highlight/HighlightEditor.cs b/Source/RaUI/UI/Scintilla.NET/Highlight/HighlightEditor.cs index 57f2307..0df7f82 100644 --- a/Source/RaUI/UI/Scintilla.NET/Highlight/HighlightEditor.cs +++ b/Source/RaUI/UI/Scintilla.NET/Highlight/HighlightEditor.cs @@ -49,7 +49,7 @@ namespace ScintillaNETV2.Highlight { Scintilla = Editor }; - AutoComplete.TargetControlWrapper = new ScintillaWrapper(Editor); + AutoComplete.TargetControlWrapper = new AutocompleteMenuNS.ScintillaWrapper(Editor); Editor.DoubleClick += Editor_DoubleClick; var ind_17= Editor.Indicators[17]; ind_17.ForeColor = Color.FromArgb(232, 232, 255); diff --git a/Source/RaUI/UI/SuperTabControl/ChromeTabControl.cs b/Source/RaUI/UI/SuperTabControl/ChromeTabControl.cs index 8248fa1..6c85220 100644 --- a/Source/RaUI/UI/SuperTabControl/ChromeTabControl.cs +++ b/Source/RaUI/UI/SuperTabControl/ChromeTabControl.cs @@ -511,8 +511,7 @@ namespace ryControls ControlStyles.UserMouse, true); tabCollection = new CustomTabPageCollection(this); this.ItemSize = new Size(TabMaxWidth, 25); - this.SizeMode = System.Windows.Forms.TabSizeMode.Fixed; - //this.AllowDrop = true; + base.SizeMode = System.Windows.Forms.TabSizeMode.Fixed; //从资源文件(嵌入到程序集)里读取图片 @@ -520,6 +519,15 @@ namespace ryControls close_normalImage = Resources.tab_close_normal; } /// + /// 获取或设置调整控件的选项卡大小的方式。 + /// + [Description("获取或设置调整控件的选项卡大小的方式。"),DefaultValue(typeof(TabSizeMode), "Fixed")] + public new TabSizeMode SizeMode + { + get { return base.SizeMode; } + set { base.SizeMode = value; } + } + /// /// /// ~ChromeTabControl() @@ -811,7 +819,19 @@ namespace ryControls /// private int GetTabTotalWidth() { - return this.ItemSize.Width * this.TabCount; + if (this.SizeMode == System.Windows.Forms.TabSizeMode.Fixed) + { + return this.ItemSize.Width * this.TabCount; + } + else + { + var total_width = 0; + for (int i = 0; i < this.TabCount; i++) + { + total_width += GetTabRect(i).Width; + } + return total_width; + } } /// /// diff --git a/Source/RaUI/UI/TreeXML/ComboBoxEx.cs b/Source/RaUI/UI/TreeXML/ComboBoxEx.cs index 89bb564..fd57c3f 100644 --- a/Source/RaUI/UI/TreeXML/ComboBoxEx.cs +++ b/Source/RaUI/UI/TreeXML/ComboBoxEx.cs @@ -29,6 +29,7 @@ namespace ryControls //ItemHeight = 50; DrawItem += OnDrawItem; } + private void OnDrawItem(object sender, DrawItemEventArgs e) { if (e.Index < 0) { return; } @@ -66,6 +67,18 @@ namespace ryControls //文本内容显示区域 textRect = new Rectangle(imgRect.Right + 2, imgRect.Y, e.Bounds.Width - imgRect.Width, e.Bounds.Height - 2); break; + case ComboPopupItem item2: + Image img2 = item2.Image; + //图片绘制的区域 + Rectangle imgRect2 = new Rectangle(6, e.Bounds.Y + 3, 16, 16); + e.Graphics.SmoothingMode = SmoothingMode.HighQuality; + e.Graphics.CompositingQuality = CompositingQuality.HighQuality; + e.Graphics.InterpolationMode = InterpolationMode.NearestNeighbor; + e.Graphics.PixelOffsetMode = System.Drawing.Drawing2D.PixelOffsetMode.Half; + e.Graphics.DrawImage(img2, imgRect2); + //文本内容显示区域 + textRect = new Rectangle(imgRect2.Right + 2, imgRect2.Y, e.Bounds.Width - imgRect2.Width, e.Bounds.Height - 2); + break; } //获得项文本内容,绘制文本 string itemText = this.Items[e.Index].ToString(); diff --git a/Source/SkinPreview/FrmTab2.Designer.cs b/Source/SkinPreview/FrmTab2.Designer.cs index 240e7a4..6255155 100644 --- a/Source/SkinPreview/FrmTab2.Designer.cs +++ b/Source/SkinPreview/FrmTab2.Designer.cs @@ -28,6 +28,12 @@ /// private void InitializeComponent() { + this.components = new System.ComponentModel.Container(); + this.CbbOpState = new ryControls.RyComboBox(); + this.htmlPanel1 = new TheArtOfDev.HtmlRenderer.WinForms.HtmlPanel(); + this.ryComboBox1 = new ryControls.RyComboBox(); + this.comboBoxEx2 = new ryControls.ComboBoxEx(); + this.comboBoxEx21 = new ryControls.ComboBoxEx2(); this.ctlMyPage1 = new MyPage.ctlMyPage(); this.textBoxEx21 = new ryControls.TextBoxEx2(); this.numericUpDownEx1 = new ryControls.NumericUpDownEx(); @@ -37,9 +43,87 @@ ((System.ComponentModel.ISupportInitialize)(this.numericUpDownEx1)).BeginInit(); this.SuspendLayout(); // + // CbbOpState + // + this.CbbOpState.DrawMode = System.Windows.Forms.DrawMode.OwnerDrawFixed; + this.CbbOpState.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList; + this.CbbOpState.FlatStyle = System.Windows.Forms.FlatStyle.Flat; + this.CbbOpState.Font = new System.Drawing.Font("宋体", 10.5F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134))); + this.CbbOpState.FormattingEnabled = true; + this.CbbOpState.ItemHeight = 24; + this.CbbOpState.Items.AddRange(new object[] { + "全部流程", + "未完成流程", + "已完成流程"}); + this.CbbOpState.Location = new System.Drawing.Point(392, 285); + this.CbbOpState.MaxUndoRedoSteps = 50; + this.CbbOpState.Name = "CbbOpState"; + this.CbbOpState.Size = new System.Drawing.Size(121, 30); + this.CbbOpState.TabIndex = 43; + // + // htmlPanel1 + // + this.htmlPanel1.AutoScroll = true; + this.htmlPanel1.AutoScrollMinSize = new System.Drawing.Size(309, 20); + this.htmlPanel1.BackColor = System.Drawing.SystemColors.Window; + this.htmlPanel1.BaseStylesheet = null; + this.htmlPanel1.Location = new System.Drawing.Point(117, 256); + this.htmlPanel1.Name = "htmlPanel1"; + this.htmlPanel1.Size = new System.Drawing.Size(309, 71); + this.htmlPanel1.TabIndex = 16; + this.htmlPanel1.Text = "htmlPanel1"; + // + // ryComboBox1 + // + this.ryComboBox1.DrawMode = System.Windows.Forms.DrawMode.OwnerDrawVariable; + this.ryComboBox1.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList; + this.ryComboBox1.FlatStyle = System.Windows.Forms.FlatStyle.Flat; + this.ryComboBox1.FormattingEnabled = true; + this.ryComboBox1.ItemHeight = 24; + this.ryComboBox1.Items.AddRange(new object[] { + "XXXCDS", + "ADDD"}); + this.ryComboBox1.Location = new System.Drawing.Point(303, 205); + this.ryComboBox1.MaxUndoRedoSteps = 50; + this.ryComboBox1.Name = "ryComboBox1"; + this.ryComboBox1.Size = new System.Drawing.Size(156, 30); + this.ryComboBox1.TabIndex = 15; + // + // comboBoxEx2 + // + this.comboBoxEx2.DrawMode = System.Windows.Forms.DrawMode.OwnerDrawFixed; + this.comboBoxEx2.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList; + this.comboBoxEx2.FlatStyle = System.Windows.Forms.FlatStyle.Flat; + this.comboBoxEx2.FormattingEnabled = true; + this.comboBoxEx2.Items.AddRange(new object[] { + "ddd", + "大大方方"}); + this.comboBoxEx2.Location = new System.Drawing.Point(27, 216); + this.comboBoxEx2.Name = "comboBoxEx2"; + this.comboBoxEx2.Size = new System.Drawing.Size(203, 22); + this.comboBoxEx2.TabIndex = 14; + // + // comboBoxEx21 + // + this.comboBoxEx21.BackColor = System.Drawing.Color.FromArgb(((int)(((byte)(236)))), ((int)(((byte)(239)))), ((int)(((byte)(244))))); + this.comboBoxEx21.ButtonRoundBackColor = System.Drawing.Color.FromArgb(((int)(((byte)(236)))), ((int)(((byte)(239)))), ((int)(((byte)(244))))); + this.comboBoxEx21.EmptyText = ""; + this.comboBoxEx21.Location = new System.Drawing.Point(48, 177); + this.comboBoxEx21.MaxPopupHeight = 0; + this.comboBoxEx21.MaxPopupWidth = 0; + this.comboBoxEx21.Name = "comboBoxEx21"; + this.comboBoxEx21.SelectedIndex = -1; + this.comboBoxEx21.SelectedItem = null; + this.comboBoxEx21.Size = new System.Drawing.Size(168, 31); + this.comboBoxEx21.TabIndex = 13; + this.comboBoxEx21.ToolTipText = ""; + // // ctlMyPage1 // + this.ctlMyPage1.CountSQL = ""; + this.ctlMyPage1.db = null; this.ctlMyPage1.Location = new System.Drawing.Point(260, 140); + this.ctlMyPage1.Multithreading = false; this.ctlMyPage1.Name = "ctlMyPage1"; this.ctlMyPage1.PageSize = 50; this.ctlMyPage1.RecordCount = 0; @@ -60,7 +144,9 @@ this.textBoxEx21.BackColor = System.Drawing.Color.White; this.textBoxEx21.EmptyText = ""; this.textBoxEx21.Location = new System.Drawing.Point(260, 107); + this.textBoxEx21.LongTime = 2000; this.textBoxEx21.MaxLength = 999999999; + this.textBoxEx21.MaxUndoRedoSteps = 50; this.textBoxEx21.Multiline = false; this.textBoxEx21.Name = "textBoxEx21"; this.textBoxEx21.OnlyNumeric = false; @@ -125,6 +211,11 @@ this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 12F); this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; this.ClientSize = new System.Drawing.Size(700, 472); + this.Controls.Add(this.CbbOpState); + this.Controls.Add(this.htmlPanel1); + this.Controls.Add(this.ryComboBox1); + this.Controls.Add(this.comboBoxEx2); + this.Controls.Add(this.comboBoxEx21); this.Controls.Add(this.ctlMyPage1); this.Controls.Add(this.textBoxEx21); this.Controls.Add(this.numericUpDownEx1); @@ -146,5 +237,10 @@ private ryControls.PanelEx panelEx1; private ryControls.ComboBoxEx comboBoxEx1; private ryControls.DateTimePickerEX dateTimePickerEX1; + private ryControls.ComboBoxEx2 comboBoxEx21; + private ryControls.ComboBoxEx comboBoxEx2; + private ryControls.RyComboBox ryComboBox1; + private TheArtOfDev.HtmlRenderer.WinForms.HtmlPanel htmlPanel1; + private ryControls.RyComboBox CbbOpState; } } \ No newline at end of file diff --git a/Source/SkinPreview/FrmTab2.cs b/Source/SkinPreview/FrmTab2.cs index b35f4f9..46151aa 100644 --- a/Source/SkinPreview/FrmTab2.cs +++ b/Source/SkinPreview/FrmTab2.cs @@ -15,6 +15,7 @@ namespace SkinPreview public FrmTab2() { InitializeComponent(); + //htmlPanel1. } } } diff --git a/Source/rycUpdate/BigFileOp.cs b/Source/rycUpdate/BigFileOp.cs index 781d3b1..679d987 100644 --- a/Source/rycUpdate/BigFileOp.cs +++ b/Source/rycUpdate/BigFileOp.cs @@ -71,17 +71,33 @@ namespace ryCommon /// /// 大文件按流复制文件,支持自动创建目标文件夹。 true:复制成功 false:复制失败 /// - /// 原始文件路径 + /// 原始文件路径 /// 复制目标文件路径 /// 携带的参数(可选) /// - public bool CopyBigFile(string soucrePath, string targetPath,object Tag=null) + public bool CopyBigFile(string sourcePath, string targetPath,object Tag=null) { try { + if(SkipSameFiles) + { + if (System.IO.File.Exists(targetPath)) + { + try + { + var target_info = new System.IO.FileInfo(targetPath); + var source_info = new System.IO.FileInfo(sourcePath); + if (target_info.Length == source_info.Length && target_info.LastWriteTimeUtc == source_info.LastWriteTimeUtc) + { + return true; + } + } + catch { } + } + } var TranSize = 1024 * 1024 * 2;//每次读取2M //读取复制文件流 - using (FileStream fsRead = new FileStream(soucrePath, FileMode.Open, FileAccess.Read)) + using (FileStream fsRead = new FileStream(sourcePath, FileMode.Open, FileAccess.Read)) { if (System.IO.File.Exists(targetPath)) { @@ -149,6 +165,14 @@ namespace ryCommon { return false; } + try + { + var source_info = new System.IO.FileInfo(sourcePath); + var target_info = new System.IO.FileInfo(targetPath); + target_info.LastWriteTime = source_info.LastWriteTime; + target_info.CreationTime = source_info.CreationTime; + } + catch{ } } return true; } @@ -217,6 +241,10 @@ namespace ryCommon catch { } } } + /// + /// 是否跳过相同文件,默认不跳过(根据文件大小和修改时间来判断) + /// + public bool SkipSameFiles { get; set; } = false; public readonly List ErrFilesList = new List(); /// /// 复制文件夹到目标文件夹,支持中途取消 @@ -234,7 +262,7 @@ namespace ryCommon var error = 0; Copy(fromDir, ToDir); Count = _count; - return error; + return -error; int Copy(string From_Dir, string To_Dir) { var _fromDir = From_Dir.TrimEnd('\\'); @@ -270,14 +298,6 @@ namespace ryCommon OnCanel?.Invoke(this, e1); if (e1.Cancel) { break; } } - if (result > 0) - { - error++; - } - else if (result < 0) - { - error += -result; - } } return -error; } diff --git a/Source/rycUpdate/Frmmain.cs b/Source/rycUpdate/Frmmain.cs index 683d2a1..b889219 100644 --- a/Source/rycUpdate/Frmmain.cs +++ b/Source/rycUpdate/Frmmain.cs @@ -302,6 +302,7 @@ namespace rycUpdate var UpdateZipPath = Application.StartupPath + "\\Update\\tmp.tmp"; var UnZipFolder = Application.StartupPath + "\\Update\\tmp"; BigFileOp bigFileOp = new BigFileOp(); + bigFileOp.SkipSameFiles = false; bigFileOp.OnFolderProgress += BigFileOp_OnFolderProgress; //this.Invoke(new Action(() => //{ @@ -364,7 +365,27 @@ namespace rycUpdate } error_id = 1003; error_msg = System.IO.Path.GetDirectoryName(UnZipFolder + "\\" + entry.FullName.Replace("/", "\\")); - entry.ExtractToFile(UnZipFolder + "\\" + entry.FullName.Replace("/", "\\"), true); + var is_same = false; + try + { + if (bigFileOp.SkipSameFiles) + { + var topath = Application.StartupPath + "\\" + entry.FullName.Replace("/", "\\").Trim('\\'); + if (System.IO.File.Exists(topath)) + { + var info = new +.IO.FileInfo(topath); + if (info.Length == entry.Length && info.LastWriteTime == entry.LastWriteTime) + { + is_same = true; + } + } + } + } + catch { } + if (!is_same) + { + entry.ExtractToFile(UnZipFolder + "\\" + entry.FullName.Replace("/", "\\"), true); + } this.Invoke(new Action(() => { progressBar1.Value = i+1; @@ -418,6 +439,7 @@ namespace rycUpdate } KillMultiProcess(list_proc); EndProcessByFolder(Application.StartupPath); + Thread.Sleep(1000); #endregion ShowState("正在更新文件..."); this.Invoke(new Action(() =>