Action11012Area.cs 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220
  1. using PaintDotNet.Base;
  2. using PaintDotNet.Base.CommTool;
  3. using PaintDotNet.Base.SettingModel;
  4. using PaintDotNet.Data.Param;
  5. using System;
  6. using System.Collections;
  7. using System.Collections.Generic;
  8. using System.Drawing;
  9. using System.IO;
  10. using System.Linq;
  11. using System.Text;
  12. using System.Threading.Tasks;
  13. using System.Windows.Forms;
  14. namespace PaintDotNet.Data.Action
  15. {
  16. public class Action11012Area : ActionAnalysis
  17. {
  18. public Action11012Area() {
  19. this.OpenImage = "current";
  20. //第一个参数
  21. lists.Add(new BooleanObject("displaygrainboundaries", "显示晶界", true, null));
  22. //第二个参数
  23. lists.Add(new BooleanObject("ShowGrainNumber", "显示晶粒编号", true, null));
  24. //第三个参数
  25. lists.Add(new BooleanObject("ShowGrainColor", "用不同颜色显示晶粒", true, null));
  26. //第四个参数
  27. lists.Add(new BooleanObject("displaygrid", "显示网格", true, null));
  28. ////第五个参数
  29. //lists.Add(new BooleanObject("displaysections", "显示截点", true, null));
  30. //第六个参数
  31. ChoiseArray selectedItem = new ChoiseArray("comboBox1SelectedItem", "选择辅助线", null);//new BooleanObject[] //{ // new BooleanObject("1", PdnResources.GetString("Menu.solid.text"), true, null),//fill // new BooleanObject("2", PdnResources.GetString("Menu.Sideline.text"), false, null)//solid //}
  32. GrainSizeGuideAreaMethodModel grainSize = XmlSerializeHelper.DESerializer<GrainSizeGuideAreaMethodModel>(FileOperationHelper.ReadStringFromFile(Application.StartupPath + "\\Config\\" + "Default"/*Startup.instance.SettingPrefix*/ + "\\" + "GrainSizeGuideAreaMethodModel.xml"/*modelName*/, FileMode.Open));
  33. selectedItem.choiseList.AddRange(getComboboxArrayList1(grainSize));
  34. if (selectedItem.choiseList.Count == 0)
  35. selectedItem.choiseList.Add(new BooleanObject(PdnResources.GetString("Menu.Pleaseselecttheauxiliarylineused.text")/*"1"/*"0"*/, PdnResources.GetString("Menu.Pleaseselecttheauxiliarylineused.text"), true, null));
  36. selectedItem.initialValue = 1;
  37. selectedItem.value = 1;
  38. selectedItem.valueType = 1;
  39. lists.Add(selectedItem);
  40. //1不包含边缘 2边缘只处理内部 3边缘处理内外部
  41. ChoiseArray one = new ChoiseArray("TargetSelection", "目标选择",
  42. new BooleanObject[]
  43. {
  44. new BooleanObject("1", "不包含边缘", true, null),
  45. new BooleanObject("2", "边缘只处理内部", false, null)
  46. }
  47. );
  48. one.initialValue = 1;
  49. one.value = 1;
  50. lists.Add(one);
  51. #region [晶界重现]
  52. ChoiseArray eleven = new ChoiseArray("GrainApplygrainboundaries", "是否应用",
  53. new BooleanObject[]
  54. {
  55. new BooleanObject("1", "是", true, null),
  56. new BooleanObject("0", "否", false, null),
  57. }
  58. );
  59. eleven.initialValue = 0;
  60. eleven.value = 0;
  61. lists.Add(eleven);
  62. //相颜色
  63. ColorNumber three = new ColorNumber();
  64. three.key = "lineColor";
  65. three.name = "相颜色";
  66. three.Value = Color.Red.ToArgb();
  67. lists.Add(three);
  68. BooleanObject eight = new BooleanObject();
  69. eight.key = "GrainIConnect";
  70. eight.name = "强制连接";
  71. eight.initialValue = false;
  72. eight.value = false;
  73. BooleanObject nine = new BooleanObject();
  74. nine.key = "GrainDisplaysections";
  75. nine.name = "晶界增强";
  76. nine.initialValue = true;
  77. nine.value = true;
  78. //西格玛
  79. DecimalNumber four = new DecimalNumber(0, 100000);
  80. four.key = "GrainSigma";
  81. four.name = "西格玛";
  82. four.DecimalPlaces = 1;
  83. four.initialValue = 1.0;
  84. four.value = 1.0;
  85. List<double> oneL = new List<double>();
  86. oneL.Add(0);
  87. oneL.Add(0);
  88. DecimalScope five = new DecimalScope(0, 10000);
  89. five.key = "GrainCell_size1";
  90. five.name = "晶界大小";
  91. five.value = oneL;
  92. ChoiseArray six = new ChoiseArray("GrainDark", "晶界类型",
  93. new BooleanObject[]
  94. {
  95. new BooleanObject("0", "亮晶界", true, null),
  96. new BooleanObject("1", "暗晶界", false, null),
  97. new BooleanObject("2", "梯度", false, null)
  98. }
  99. );
  100. six.initialValue = 0;
  101. six.value = 0;
  102. ChoiseArray seven = new ChoiseArray("GrainSmooth_type", "去噪类型",
  103. new BooleanObject[]
  104. {
  105. new BooleanObject("0", "高斯平滑", true, null),
  106. new BooleanObject("1", "方向平滑", false, null),
  107. }
  108. );
  109. seven.initialValue = 0;
  110. seven.value = 0;
  111. ChoiseArray two = new ChoiseArray("GrainM_iStandardImage", "标准图像",
  112. new BooleanObject[]
  113. {
  114. new BooleanObject("0", "否", false, new Args[]{
  115. nine,
  116. four,
  117. five,
  118. six,
  119. seven
  120. }),
  121. new BooleanObject("1", "是", true, new Args[]{
  122. eight
  123. }),
  124. }
  125. );
  126. two.initialValue = 0;
  127. two.value = 0;
  128. lists.Add(two);
  129. #endregion
  130. }
  131. public List<Args> getComboboxArrayList1(GrainSizeGuideAreaMethodModel grainSize)
  132. {
  133. ArrayList arrayList0 = new ArrayList();
  134. List<Args> arrayList1 = new List<Args>();
  135. List<int> indexList1 = new List<int>();
  136. // 圆样式
  137. if (grainSize.circularGuideStyles != null)
  138. {
  139. foreach (var vGuideStyle in grainSize.circularGuideStyles)
  140. {
  141. //if (arrayList1.Count == 0)
  142. // arrayList1.Add(new BooleanObject("1"/*"0"*/, vGuideStyle.tag, true, null));
  143. //else
  144. // arrayList1.Add(new BooleanObject((arrayList1.Count + 1).ToString(), vGuideStyle.tag, false, null));
  145. arrayList0.Add(vGuideStyle.tag/*""*/);
  146. indexList1.Add(vGuideStyle.index);
  147. }
  148. }
  149. // 矩形样式
  150. if (grainSize.rectangleGuideStyles != null)
  151. {
  152. foreach (var hGuideStyle in grainSize.rectangleGuideStyles)
  153. {
  154. //if (arrayList1.Count == 0)
  155. // arrayList1.Add(new BooleanObject("1"/*"0"*/, hGuideStyle.tag, true, null));
  156. //else
  157. // arrayList1.Add(new BooleanObject((arrayList1.Count + 1).ToString(), hGuideStyle.tag, false, null));
  158. arrayList0.Add(hGuideStyle.tag/*""*/);
  159. indexList1.Add(hGuideStyle.index);
  160. }
  161. }
  162. if (arrayList0.Count > 0)
  163. {
  164. bool sortSuccess = false;
  165. while (!sortSuccess)
  166. {
  167. sortSuccess = true;
  168. int firstIndex = 0;
  169. int secondIndex = 0;
  170. for (int i = 0; i < indexList1.Count; i++)
  171. {
  172. for (int j = i + 1; j < indexList1.Count; j++)
  173. {
  174. if (indexList1[i] > indexList1[j])
  175. {
  176. sortSuccess = false;
  177. firstIndex = i;
  178. secondIndex = j;
  179. }
  180. }
  181. if (!sortSuccess)
  182. break;
  183. }
  184. string firstValue = arrayList0[firstIndex] + "";
  185. arrayList0[firstIndex] = arrayList0[secondIndex] + "";
  186. arrayList0[secondIndex] = firstValue;
  187. int firstIndexV = indexList1[firstIndex] + 0;
  188. indexList1[firstIndex] = indexList1[secondIndex] + 0;
  189. indexList1[secondIndex] = firstIndexV;
  190. }
  191. for (int i = 0; i < arrayList0.Count; i++)
  192. {
  193. if (i == 0)
  194. arrayList1.Add(new BooleanObject(arrayList0[i].ToString()/*"1"*/, arrayList0[i].ToString(), true, null));
  195. else
  196. arrayList1.Add(new BooleanObject(arrayList0[i].ToString()/*(arrayList1.Count + 1).ToString()*/, arrayList0[i].ToString(), false, null));
  197. }
  198. //arrayList1.Insert(0, PdnResources.GetString("Menu.Pleaseselecttheauxiliarylineused.text"));
  199. }
  200. return arrayList1;
  201. }
  202. }
  203. }