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(() =>