using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; using DevComponents.DotNetBar; using GeoScene.Engine; using GeoScene.Globe; using GeoScene.Data; namespace PipeLine.Forms { public partial class FrmDianLiAttribute : Office2007Form { private GSOFeatureDataset featDataSet; private GSOLayer layer; public GSOFeature feat_old; public GSOFeature feat; public GSOGeoPolyline3D line; private Color color; public FrmDianLiAttribute(GSOLayer _layer, GSOFeature feature,Color color1) { InitializeComponent(); layer = _layer; featDataSet = layer.Dataset as GSOFeatureDataset; line = feature.Geometry as GSOGeoPolyline3D; feat_old = feature; color = color1; } private void btnOK_Click(object sender, EventArgs e) { feat = featDataSet.CreateFeature(); GSOPipeLineStyle3D style = new GSOPipeLineStyle3D(); style.LineColor = color; //GSOFeatures feats = layer.GetAllFeatures(); //if (feats.Length > 0) //{ // GSOFeature colorFeat = feats[0]; // GSOPipeLineStyle3D originstyle = colorFeat.Geometry.Style as GSOPipeLineStyle3D; // if (originstyle != null) // style.LineColor = originstyle.LineColor; //} if (txtGuanJing.Text == "" || txtGuanJing.Text == "0") { if (txtGuanJing.Text == "") { MessageBox.Show("管径不能为空!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Warning); } else { MessageBox.Show("管径不能为零!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Warning); } return; } else { style.Radius = Convert.ToDouble(txtGuanJing.Text) / 2000; } line.AltitudeMode = EnumAltitudeMode.RelativeToGround; line.Style = style; GSOPoint3ds pts = line[0]; GSOPoint3d pt1 = pts[0]; GSOPoint3d pt2 = pts[1]; if (txtDeep1.Text == "" || txtDeep1.Text == "0" || txtDeep2.Text == "" || txtDeep2.Text == "0") { if (txtDeep1.Text == "" || txtDeep2.Text == "") { MessageBox.Show("起始埋深和终止埋深不能为空!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Warning); } else if (txtDeep1.Text == "0" || txtDeep2.Text == "0") { MessageBox.Show("起始埋深和终止埋深埋深不能为零!", "提示!", MessageBoxButtons.OK, MessageBoxIcon.Warning); } return; } pt1.Z = 0 - Convert.ToDouble(txtDeep1.Text) - Convert.ToDouble(txtGuanJing.Text)/1000; pt2.Z = 0 - Convert.ToDouble(txtDeep2.Text) - Convert.ToDouble(txtGuanJing.Text)/1000; pts[0] = pt1; pts[1] = pt2; feat.Geometry = line; if (txtBianHao.Text == "") { MessageBox.Show("请输入“编号”,该字段不能为空!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Warning); return; } else feat.SetValue("编号", txtBianHao.Text); if (combBianMa.SelectedItem != null) { feat.SetValue("管线编码", combBianMa.SelectedItem); } if (txtGuanJing.Text != "") { feat.SetValue("管径_毫米", Convert.ToInt32(txtGuanJing.Text)); } if (combMaterial.SelectedIndex >0) { feat.SetValue("材质", combMaterial.SelectedItem.ToString()); } if (combMaiShe.SelectedIndex >0) { feat.SetValue("埋设方式", combMaiShe.SelectedItem.ToString()); } if (txtYali.Text != "") { feat.SetValue("电压", Convert.ToDouble(txtYali.Text)); } if (txtDEM1.Text != "") { feat.SetValue("起始地面高程", Convert.ToDouble(txtDEM1.Text)); } if (txtDeep1.Text != "") { feat.SetValue("起始埋深", Convert.ToDouble(txtDeep1.Text)); } if (txtDEMDing1.Text != "") { feat.SetValue("起始管顶高程", Convert.ToDouble(txtDEMDing1.Text)); } if (txtDEM2.Text != "") { feat.SetValue("终止地面高程", Convert.ToDouble(txtDEM2.Text)); } if (txtDeep2.Text != "") { feat.SetValue("终止埋深", Convert.ToDouble(txtDeep2.Text)); } if (txtDEMDing2.Text != "") { feat.SetValue("终止管顶高程", Convert.ToDouble(txtDEMDing2.Text)); } if (txtDianlanNum.Text != "") { feat.SetValue("电缆条数", Convert.ToInt32 (txtDianlanNum.Text)); } if (txtGuanglanNum.Text != "") { feat.SetValue("光缆条数", Convert.ToInt32(txtGuanglanNum.Text)); } if (txtUseNumKong.Text != "") { feat.SetValue("已用孔数", Convert.ToInt32(txtUseNumKong.Text)); } if (txtAllNumKong.Text != "") { feat.SetValue("总孔数", Convert.ToInt32(txtAllNumKong.Text)); } if (dateBuild.Text != "") { feat.SetValue("建设年代", Convert.ToDateTime(dateBuild.Text)); } if (txtYear.Text != "") { feat.SetValue("使用年限", Convert.ToDouble(txtYear.Text)); } feat.SetValue("电缆型号", txtCamble_Type .Text ); feat.SetValue("线路起点", txtStartPlace.Text ); feat.SetValue("线路终点", txtEndPlace.Text); feat.SetValue("权属单位", txtQuanShuDanWei.Text); feat.SetValue("设计单位", txtDesign_Com.Text); feat.SetValue("设计负责人", txtDesign_Per.Text); feat.SetValue("施工单位", txtBuilder_Com.Text); feat.SetValue("施工负责人", txtBuilder_Per.Text); feat.SetValue("监理单位", txtMon_Com.Text); feat.SetValue("监理负责人", txtMon_Per.Text); feat.SetValue("业务负责人", txtHH_Per.Text); feat.SetValue("备注", txtRemark.Text); feat.Name = txtBianHao.Text; line.Name = txtBianHao.Text; layer.AddFeature(feat); feat_old.Delete(); this.DialogResult = DialogResult.OK; this.Close(); } private void btnCancel_Click(object sender, EventArgs e) { this.DialogResult = DialogResult.Cancel; this.Close(); } private void txtBianMa_KeyPress(object sender, KeyPressEventArgs e) { TextBox text = sender as TextBox; if ((e.KeyChar < 48 || e.KeyChar > 57) && (e.KeyChar != 8) && (int)e.KeyChar != 46) { e.Handled = true; } if ((int)e.KeyChar == 46) //小数点 { if (text.Text.Length <= 0) e.Handled = true; //小数点不能在第一位 else //处理不规则的小数点 { float f; float oldf; bool b1 = false, b2 = false; b1 = float.TryParse(text.Text, out oldf); b2 = float.TryParse(text.Text + e.KeyChar.ToString(), out f); if (b2 == false) { if (b1 == true) e.Handled = true; else e.Handled = false; } } } } private void FrmDianLiAttribute_Load(object sender, EventArgs e) { string str = Utility.Pipe_Code["电力"].ToString(); string[] aArray = str.Split(','); for (int i = 0; i < aArray.Length; i++) { combBianMa.Items.Add(aArray[i]); } combBianMa.SelectedIndex = 0; txtBianHao.Text = Guid.NewGuid().ToString(); string sqltype1 = "select distinct 材质 from 电力管线"; DataTable table1 = OledbHelper.QueryTable(sqltype1); combMaterial.Items.Add("无"); for (int j = 0; j < table1.Rows.Count; j++) { DataRow dr = table1.Rows[j]; string colString1 = dr[0].ToString(); if (colString1 == null || colString1.Trim() == "") continue; combMaterial.Items.Add(colString1); } string sqltype2 = "select distinct 埋设方式 from 电力管线"; DataTable table2 = OledbHelper.QueryTable(sqltype2); combMaiShe.Items.Add("无"); for (int k = 0; k < table2.Rows.Count; k++) { DataRow dr = table2.Rows[k]; string colString1 = dr[0].ToString(); if (colString1 == null || colString1.Trim() == "") continue; combMaiShe.Items.Add(colString1); } } } }