Beispiel #1
0
 private void DeleteRowCircle()
 {
     if (mgCircles.GetListCircles().Count == 0)
     {
         BS_LiteCAD.ShowNotifyAutoHide(elementHost1, "Không có lỗ khoan");
     }
     else
     {
         List <Circle> listCircle  = mgCircles.GetListCircleOfFirstRow();
         int           hBlockModel = Lcad.PropGetHandle(hDrw, Lcad.LC_PROP_DRW_BLOCK_MODEL);
         Lcad.BlockUnselect(hBlockModel);
         //xóa hàng lỗ khoan mới
         mgCircles.RemoveListCircles(listCircle);
         foreach (var circle in listCircle)
         {
             Lcad.BlockSelectEnt(hBlockModel, circle.GetHandle(), true);
             Lcad.BlockSelErase(hBlockModel);
             Lcad.BlockUnselect(hBlockModel);
         }
         //thêm lưới tọa độ
         if (this.banVeChinh.HienKhoangCach)   //sau them dk vao day
         {
             Lcad.LayerClear(layerLuoiKichThuoc, hBlockModel);
             DungLuoiKichThuoc();
         }
         //load lại
         Lcad.DrwRegenViews(hDrw, 0);
         Lcad.WndExeCommand(hWnd, Lcad.LC_CMD_ZOOM_EXT, 0);
     }
 }
Beispiel #2
0
 private void AddRowCircle()
 {
     if (mgCircles.GetListCircles().Count == 0)
     {
         BS_LiteCAD.ShowNotifyAutoHide(elementHost1, "Không có lỗ khoan");
     }
     else
     {
         List <Circle> listCircle    = mgCircles.GetListCircleOfFirstRow();
         List <Circle> listNewCircle = new List <Circle>();
         int           hBlockModel   = Lcad.PropGetHandle(hDrw, Lcad.LC_PROP_DRW_BLOCK_MODEL);
         Lcad.BlockUnselect(hBlockModel);
         //thêm hàng lỗ khoan mới
         foreach (var circle in listCircle)
         {
             int newHEnt = Lcad.BlockAddClone(hBlockModel, circle.GetHandle());
             Lcad.BlockSelectEnt(hBlockModel, newHEnt, true);
             Lcad.BlockSelMove(hBlockModel, 0, mgCircles.GetDeltaY(), false, true);
             Lcad.BlockUnselect(hBlockModel);
             listNewCircle.Add(new Circle(newHEnt));
         }
         mgCircles.AddListCircle(listNewCircle);
         //thêm lưới tọa độ
         if (this.banVeChinh.HienKhoangCach)
         {
             Lcad.LayerClear(layerLuoiKichThuoc, hBlockModel);
             DungLuoiKichThuoc();
         }
         //load lại
         Lcad.DrwRegenViews(hDrw, 0);
         Lcad.WndExeCommand(hWnd, Lcad.LC_CMD_ZOOM_EXT, 0);
     }
 }
Beispiel #3
0
        //dựng lưới kích thước lỗ khoan
        private void DungLuoiKichThuoc()
        {
            //xóa lớp lưới cũ
            Lcad.LayerClear(layerLuoiKichThuoc, Lcad.PropGetHandle(hDrw, Lcad.LC_PROP_DRW_BLOCK_MODEL));
            List <Circle> danhSachLoKhoan = mgCircles.GetListCircles();

            for (int i = 0; i < danhSachLoKhoan.Count - 1; i++)
            {
                for (int j = i + 1; j < danhSachLoKhoan.Count; j++)
                {
                    double length = Math.Sqrt(Math.Pow((danhSachLoKhoan[i].GetX() - danhSachLoKhoan[j].GetX()), 2) + Math.Pow((danhSachLoKhoan[i].GetY() - danhSachLoKhoan[j].GetY()), 2));
                    if (Math.Round(length) == Math.Round(this.banVeChinh.DeltaX))
                    {
                        VeKhoangCach(danhSachLoKhoan[i], danhSachLoKhoan[j]);
                    }
                    else
                    {
                        if (Math.Round(length) == Math.Round(this.banVeChinh.DeltaY))
                        {
                            VeKhoangCach(danhSachLoKhoan[i], danhSachLoKhoan[j]);
                        }
                    }
                }
            }
            Lcad.DrwRegenViews(hDrw, 0);
            Lcad.WndExeCommand(hWnd, Lcad.LC_CMD_ZOOM_EXT, 0);
        }
Beispiel #4
0
 //tính toán khoanh vùng
 private void KhoanhVungLoKhoan()
 {
     if (mgCircles.GetListCircles().Count == 0)
     {
         BS_LiteCAD.ShowNotifyAutoHide(elementHost1, "Không có lỗ khoan");
     }
     else
     {
         double xMax, xMin, yMax, yMin;
         if (xFirstPoint > xLastPoint)
         {
             xMax = xFirstPoint;
             xMin = xLastPoint;
         }
         else
         {
             xMax = xLastPoint;
             xMin = xFirstPoint;
         }
         if (yFirstPoint > yLastPoint)
         {
             yMax = yFirstPoint;
             yMin = yLastPoint;
         }
         else
         {
             yMax = yLastPoint;
             yMin = yFirstPoint;
         }
         List <Circle> listCircle       = mgCircles.GetListCircles();
         List <Circle> listRemoveCircle = new List <Circle>();
         int           hBlockModel      = Lcad.PropGetHandle(hDrw, Lcad.LC_PROP_DRW_BLOCK_MODEL);
         foreach (Circle value in listCircle)
         {
             if (value.GetX() > xMax || value.GetX() < xMin || value.GetY() > yMax || value.GetY() < yMin)
             {
                 listRemoveCircle.Add(value);
                 Lcad.BlockSelectEnt(hBlockModel, value.GetHandle(), true);
                 Lcad.BlockSelErase(hBlockModel);
                 Lcad.BlockUnselect(hBlockModel);
             }
         }
         //xóa danh sách nằm ngoài
         mgCircles.RemoveListCircles(listRemoveCircle);
         //vẽ lại lưới tọa độ
         if (this.banVeChinh.HienKhoangCach)   //sau them dk vao day
         {
             Lcad.LayerClear(layerLuoiKichThuoc, hBlockModel);
             DungLuoiKichThuoc();
         }
         //load lại
         Lcad.DrwRegenViews(hDrw, 0);
         Lcad.WndExeCommand(hWnd, Lcad.LC_CMD_ZOOM_EXT, 0);
         SendKeys.Send("{ESC}");
     }
 }
Beispiel #5
0
        private void loadFile_FormMoBanVeDatabase(String idHoChieu)
        {
            this.hoChieuChinh = BS_HoChieu.HoChieu(idHoChieu);
            this.banVeChinh   = BS_BanVe.BanVe(this.hoChieuChinh.MaBanVe);
            List <LoKhoan> danhSachLoKhoan = BS_LoKhoan.DanhSachLoKhoan(idHoChieu);
            List <Circle>  danhSachCircle  = new List <Circle>();

            mgCircles = new ManageCircle();
            //dựng bản vẽ mới
            //this.banVeChinh.HienKhoangCach = false;
            this.Text = "Bản vẽ: [" + this.banVeChinh.TenBanVe + "]";
            Lcad.DrwLoad(hDrw, BS_Template.ChonTemplate(this.banVeChinh.Template).DuongDan, this.Handle, hWnd);
            layerLoMin         = Lcad.DrwAddLayer(hDrw, "LoMin", "cyan", 0, Lcad.LC_LWEIGHT_DEFAULT);
            layerLuoiKichThuoc = Lcad.DrwAddLayer(hDrw, "LuoiKichThuoc", "foreground", 0, Lcad.LC_LWEIGHT_DEFAULT);
            int hBlockModel = Lcad.PropGetHandle(hDrw, Lcad.LC_PROP_DRW_BLOCK_MODEL);

            foreach (LoKhoan value in danhSachLoKhoan)
            {
                int hEntCircle = Lcad.BlockAddCircle(hBlockModel, value.ToaDoX, value.ToaDoY, value.BanKinh, false);
                Lcad.PropPutInt(hEntCircle, Lcad.LC_PROP_ENT_ID, int.Parse(value.MaLoKhoan));
                Lcad.PropPutInt(hEntCircle, Lcad.LC_PROP_ENT_KEY, keyCircle);
                Lcad.PropPutStr(hEntCircle, Lcad.LC_PROP_ENT_LAYER, "LoMin");
                danhSachCircle.Add(new Circle(hEntCircle));
            }
            mgCircles.AddListCircle(danhSachCircle);
            if (banVeChinh.HienKhoangCach)
            {
                Lcad.LayerClear(layerLuoiKichThuoc, hBlockModel);
                DungLuoiKichThuoc();
            }
            //vẽ lại hình
            Lcad.DrwRegenViews(hDrw, 0);
            Lcad.WndExeCommand(hWnd, Lcad.LC_CMD_ZOOM_EXT, 0);
            BS_LiteCAD.ShowNotifyAutoHide(elementHost1, this.banVeChinh.TenBanVe + " - đã mở");
            //mở form dựng lưới lỗ khoan
            if (mgCircles.GetListCircles().Count == 0)
            {
                FormXayDungLoKhoan fm = new FormXayDungLoKhoan();
                fm.MyGetData = new FormXayDungLoKhoan.GetData(loadFile_FormXayDungLoKhoan);
                fm.Show();
            }
        }
Beispiel #6
0
        private void MouseDblClkProc_XayDungLuoiLoMin(int hWnd, int Button, int Flags, int Xwin, int Ywin, double Xdrw, double Ydrw)
        {
            int hBlockModel = Lcad.PropGetHandle(hDrw, Lcad.LC_PROP_DRW_BLOCK_MODEL);

            if (mgCircles == null)
            {
                mgCircles = new ManageCircle();
            }
            else
            {
                Lcad.LayerClear(layerLoMin, hBlockModel);
                Lcad.LayerClear(layerLuoiKichThuoc, hBlockModel);
                mgCircles = new ManageCircle();
            }
            int hEntCircle = Lcad.BlockAddCircle(hBlockModel, Xdrw, Ydrw, banKinh, false);

            Lcad.PropPutInt(hEntCircle, Lcad.LC_PROP_ENT_KEY, keyCircle);
            Lcad.PropPutStr(hEntCircle, Lcad.LC_PROP_ENT_LAYER, "LoMin");
            Lcad.BlockUnselect(hBlockModel);
            //tạo danh sách cột đầu tiên
            List <Circle> listCotDau = new List <Circle>();
            Circle        root       = new Circle(hEntCircle);

            listCotDau.Add(root);
            //tạo cột đầu tiên từ điểm gốc (số điểm trong cột ứng với số hàng trừ đi điểm gốc)
            for (int i = 0; i < soHang - 1; i++)
            {
                int newHEnt = Lcad.BlockAddClone(hBlockModel, listCotDau[i].GetHandle());
                Lcad.PropPutInt(newHEnt, Lcad.LC_PROP_ENT_KEY, keyCircle);
                Lcad.BlockSelectEnt(hBlockModel, newHEnt, true);
                Lcad.BlockSelMove(hBlockModel, 0, khoangCachHang, false, true);
                Lcad.BlockUnselect(hBlockModel);
                listCotDau.Add(new Circle(newHEnt));
            }
            mgCircles.AddListCircle(listCotDau);
            //thêm các cột còn lại (ứng với số cột trừ đi cột đầu)
            for (int i = 0; i < soCot - 1; i++)
            {
                List <Circle> listCotGanNhat = new List <Circle>();
                List <Circle> listCotMoi     = new List <Circle>();
                if (khoangCachCot > 0)
                {
                    listCotGanNhat = mgCircles.GetListCirleOfLastColumn();
                }
                else
                {
                    listCotGanNhat = mgCircles.GetListCirleOfFirstColumn();
                }
                foreach (var circle in listCotGanNhat)
                {
                    int newHEnt = Lcad.BlockAddClone(hBlockModel, circle.GetHandle());
                    Lcad.PropPutInt(newHEnt, Lcad.LC_PROP_ENT_KEY, keyCircle);
                    Lcad.BlockSelectEnt(hBlockModel, newHEnt, true);
                    Lcad.BlockSelMove(hBlockModel, khoangCachCot, 0, false, true);
                    Lcad.BlockUnselect(hBlockModel);
                    listCotMoi.Add(new Circle(newHEnt));
                }
                mgCircles.AddListCircle(listCotMoi);
            }
            //hiển thị lưới kích thước
            if (this.banVeChinh.HienKhoangCach)
            {
                DungLuoiKichThuoc();
            }
            //load lại
            //MessageBox.Show("hang" + soHang + "\ncot" + soCot + "\nkc hang" + khoangCachHang + "\nkc cot" + khoangCachCot + "\nX" + Xdrw + "\nY" + Ydrw);
            Lcad.DrwRegenViews(hDrw, 0);
            Lcad.WndExeCommand(hWnd, Lcad.LC_CMD_ZOOM_EXT, 0);
            Lcad.OnEventMouseDblClk(_EventMouseDbclick_LoMin);
            LuuHoChieu(this.hoChieuChinh.MaHoChieu);    //ăn gian...
            BS_LiteCAD.ShowNotifyAutoHide(elementHost1, "Xây dựng lưới lỗ khoan - hoàn thành");
        }