Action1102512.cs 9.4 KB

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