C# SolidWorks 二次开发 API —在自己的网页中嵌入eDrawings Web Viewer

C# SolidWorks 二次开发 API —在自己的网页中嵌入eDrawings Web Viewer

这是Solidworks PDM系统中的Web2客户端,能够实现对很多3D图在web端的预览,我们先不考虑PDM这么 高深的问题,今天我来给大家介绍一下如何把这个功能集成到自己的网页中,实现预览3D格式。

通过网页端的请求分析,以及后端服务器的对比,发现web版的edrawing是利用了新的scs格式来进行中转的,没有直接在web上对solidworks的原档进行解析,这样保证了数据的安全。

它利用了一个在线的服务来进行文件的转换,下图是3dcontentcentral这个网站上的请求截图:


在发布好web2客户端后,发现里面会有一个eDrawingsWebViewer的文件夹:里面就有转换的文件夹,再次进行研究

找到了一个转换的Exe文件,在cmd命令下直接有提示,传入输入的格式,以及输出的地址,就可以转换成scs文件了。
经过测试,这个转换工具可以直接转换x_t step等中间格式为scs文件,还是很厉害的。

最后在本地部署iis下直接 在Site文件夹下 打开main.html,并传入URL即可显示:


当前它本来有一个中转的服务,这个需要大家自己去处理。目前还没在把服务研究透。

下面是测量的截图

posted @
2020-04-30 21:37 
painezeng  阅读(
389)  评论(
2
编辑 
收藏 
举报

Vb.net SolidWorks 二次开发 API —在的窗口中嵌入eDrawing

Vb.net SolidWorks 二次开发 API —在的窗口中嵌入eDrawing

在自己的窗口中嵌入eDrawing

eDrawing是一个可以预览solidworks等多个格式的文件,从2019版本开始,edrawing还可以直接打开x_t step等第三方格式,支持直接预览操作,并且支持简单测量(可以开发一些其它测量功能),以前是需要License的。

预览图如下:

需要源码的大家自行下载。

我放了一个帮助文档,大家可以进去看看。

posted @
2020-04-24 14:48 
painezeng  阅读(
256)  评论(
0
编辑 
收藏 
举报

C# SolidWorks 二次开发 API —只开工程图的情况下直接转出3D和2D

C# SolidWorks 二次开发 API —只开工程图的情况下直接转出3D和2D

##昨天晚上有网友咨询了一个问题,问如何只打开工程图的情况下导出step与pdf.

之前我写的博客中存3D格式是在打开的情况下做的,之前我的一篇文章中有写过怎么在工程图中获取零件对象,所以我们只需要在那上面改一改就可以了。直接调用ModelDoc2.Extension.SaveAs方法就可以存成想要的格式,而不产生单独打开窗口的动作了。

代码如下:

           //连接到Solidworks
            ISldWorks swApp = Utility.ConnectToSolidWorks();

            ModelDoc2 swModel = (ModelDoc2)swApp.ActiveDoc;

            // DrawingDoc dc = (DrawingDoc)swModel;

            SelectionMgr selectionMgr = (SelectionMgr)swModel.SelectionManager;

            //获取选择的视图对象
            View view = (View)selectionMgr.GetSelectedObject5(1);

            //获取视图中的引用模型
            var viewModel = view.ReferencedDocument;

            //其它读取属性请参考博文 读取零件属性 ->BtnGetPartData_Click

            MessageBox.Show(viewModel.GetPathName());

            //下面是导出,如果不需要请注释掉以下代码。
            int error = 0;
            int warnings = 0;

            var stepName = System.IO.Path.GetFileNameWithoutExtension(viewModel.GetPathName());

            var bRes = viewModel.Extension.SaveAs($@"D:\{stepName}.step", (int)swSaveAsVersion_e.swSaveAsCurrentVersion, (int)swSaveAsOptions_e.swSaveAsOptions_Silent, null, ref error, ref warnings);

            if (bRes == true)
            {
                MessageBox.Show("Export step Done!");
            }
            else
            {
                MessageBox.Show("Export Error!");
            }

代码已经发布在码云和github.

posted @
2020-04-23 11:31 
painezeng  阅读(
180)  评论(
0
编辑 
收藏 
举报

C# SolidWorks 二次开发 API —工程图中的图层读取与新建

C# SolidWorks 二次开发 API —工程图中的图层读取与新建

工程图中为了便于输出不同颜色的的对象信息,如颜色和线型,有时候会在工程图中建立各种各样的图层。
此文章的目标就是图层的管理。
前提条件:打开一张工程图
实现目标:遍历显示当前图纸中图层的信息,根据需要建立自己需要的图层。

关于图层,英文名是Layer:
我们先看一下Solidworks Api帮助中的信息:发现里面有例子,所以我们就可以直接参考了

如下图,我们当前打开的图纸中,有四个图层

下面先看一下获取这些图层的信息
直接上代码:

 ISldWorks swApp = Utility.ConnectToSolidWorks();

            var swModel = (ModelDoc2)swApp.ActiveDoc;

            var swLayerMgr = (LayerMgr)swModel.GetLayerManager();

            //获取当前图层数量
            var layCount = swLayerMgr.GetCount();

            var layerList = (String[])swLayerMgr.GetLayerList();

            foreach (var lay in layerList)
            {
                var currentLayer = swLayerMgr.GetLayer(lay);
                if (currentLayer != null)
                {
                    var currentName = currentLayer.Name;
                    //颜色的Ref值
                    var currentColor = currentLayer.Color;
                    var currentDesc = currentLayer.Description;

                    //swLineStyles_e 对应的值
                    var currentStype = Enum.GetName(typeof(swLineStyles_e), currentLayer.Style);

                    var currentWidth = currentLayer.Width;

                    int refcolor = currentColor;
                    int blue = refcolor >> 16 & 255;
                    int green = refcolor >> 8 & 255;
                    int red = refcolor & 255;
                    int colorARGB = 255 << 24 | (int)red << 16 | (int)green << 8 | (int)blue;

                    //得到对应的RGB值
                    Color ARGB = Color.FromArgb(colorARGB);  //得到结果

                    Debug.Print($"图层名称:{currentName}");
                    Debug.Print($"图层颜色:R {ARGB.R},G {ARGB.G} ,B {ARGB.B}");
                    Debug.Print($"图层描述:{currentDesc}");
                    Debug.Print($"图层线型:{currentStype}");
                    Debug.Print($"-------------------------------------");
                }
            }

运行一下,结果如下图:
可以看到Layer0的 颜色 R 255 G 0 B 0 就是红色。

接下来看看如何增加一个图层。
比如说我要增加一个紫色的图层。

            //下面来建图层。

            var swDrawing = (DrawingDoc)swModel;

            // var colorString = "Purple";
            Color color = Color.Purple; //System.Drawing.ColorTranslator.FromHtml(colorString); 如果是字符串可以通过这转
            //给定的
            int colorInt = color.ToArgb();
            int red2 = colorInt >> 16 & 255;
            int green2 = colorInt >> 8 & 255;
            int blue2 = colorInt & 255;
            int refcolor2 = (int)blue2 << 16 | (int)green2 << 8 | (int)red2;

            var bRes = swDrawing.CreateLayer2("NewPurple", "New Purple Layout ", (int)refcolor2, (int)swLineStyles_e.swLineCONTINUOUS, (int)swLineWeights_e.swLW_NORMAL, true, true);

            if (bRes == true)
            {
                Debug.Print($"图层已经创建");
            }

运行之后,图层已经创建完成,这样我们就可以再进行别的操作了。


老样子,代码自取。希望口味喜欢。

图层的一些删除操作就比较简单了,我就不演示了,它也没有几个方法。

posted @
2020-04-22 20:13 
painezeng  阅读(
388)  评论(
0
编辑 
收藏 
举报

C# SolidWorks 二次开发 API —工程图尺寸信息的读取

C# SolidWorks 二次开发 API —工程图尺寸信息的读取

工程图尺寸信息的读取

前提条件: 在打开的工程图选中一个尺寸
本文目标: 通过转换选择的尺寸为一个尺寸对象,获取该尺寸的值与公差。


 private void btnGetDimensionInfo_Click(object sender, EventArgs e)
        {
            ISldWorks swApp = Utility.ConnectToSolidWorks();
            swApp.CommandInProgress = true;

            ModelDoc2 swModel = (ModelDoc2)swApp.ActiveDoc;

            SelectionMgr selectionMgr = (SelectionMgr)swModel.SelectionManager;

            //转换成尺寸显示对象
            var swDisplayDimension = (DisplayDimension)selectionMgr.GetSelectedObject6(1, 0);

            DisplayData displayData = (DisplayData)swDisplayDimension.GetDisplayData();

            //获取尺寸上的文字
            var anno = (Annotation)swDisplayDimension.GetAnnotation();

            //获取所在视图 ---如果是图纸,这里会报错。需要用OwnerType来判断
            var thisView = (View)anno.Owner;//

            var textwidth = displayData.GetTextInBoxWidthAtIndex(0);

            var textHeight = displayData.GetTextHeightAtIndex(0);

            // dat.GetLineCount 几条线
            var lineCount = displayData.GetLineCount();
            var lineAngle = displayData.GetTextAngleAtIndex(0);
            var linePoints = (double[])displayData.GetLineAtIndex(0);
            var linePoints2 = (double[])displayData.GetLineAtIndex(1);
            var textPoint = (double[])displayData.GetTextPositionAtIndex(0);

            var thisDimAng = lineAngle * 180 / Math.PI;

            //尺寸对象
            var swDimension = (Dimension)swDisplayDimension.GetDimension();

            //获取尺寸的公差
            var cruToleranceType = swDimension.GetToleranceType();
            var cruTolerance = swDimension.Tolerance;

            if (cruToleranceType == (int)swTolType_e.swTolBILAT)
            {
                cruTolerance.GetMaxValue2(out double ToleranceValueMax); //上公差

                cruTolerance.GetMinValue2(out double ToleranceValueMin);//下公差
            }

            var TextAll = swDisplayDimension.GetText((int)swDimensionTextParts_e.swDimensionTextAll);
            var TextPrefix = swDisplayDimension.GetText((int)swDimensionTextParts_e.swDimensionTextPrefix);
            var TextSuffix = swDisplayDimension.GetText((int)swDimensionTextParts_e.swDimensionTextSuffix);
            var CalloutAbove = swDisplayDimension.GetText((int)swDimensionTextParts_e.swDimensionTextCalloutAbove);
            var CalloutBelow = swDisplayDimension.GetText((int)swDimensionTextParts_e.swDimensionTextCalloutBelow);

            var relValue = Math.Round(swDimension.GetSystemValue2("") * 1000, 3).ToString();

            MessageBox.Show(relValue);
        }

上面是代码,有一些备注。

这是初学markdown写的, 源代码继续在码云或者github上拿。

posted @
2020-04-20 14:07 
painezeng  阅读(
272)  评论(
0
编辑 
收藏 
举报

C# SolidWorks 二次开发 API —Solidworks的多开操作与连接指定版本Solidworks

C# SolidWorks 二次开发 API —Solidworks的多开操作与连接指定版本Solidworks

        今天有网友问我关于如何用Exe操作多个Solidworks的问题,其实之前我看到过解决方案,是通过进程和id获取,而不是我们平时常用的 (SldWorks)Marshal.GetActiveObject(“SldWorks.Application.27”);

        所以晚上回来查了些资料,发现了有了解决方案,我精简了一下,做了个dll.大家可以试试。    

 ''' <summary>
    ''' 创建一个新的Solidworks并返回实例
    ''' </summary>
    ''' <param name="version">指定版本号,-1表示默认.</param>
    ''' <param name="suppressDialogs">True 则禁用solidworks弹出消息.</param>
    ''' <param name="requireMainWindow">True 表示运行完显示到主窗口</param>
    ''' <param name="startProcessTimeout">返回Null 如果SolidWorks在指定时间内没有打开。</param>
    ''' <param name="createWindowTimeout">返回Null 如果SolidWorks主窗口在指定时间内没有显示.</param>
    ''' <returns></returns>
    Public Shared Function RunSolidWorks(version As Integer,
                                         visible As Boolean,
                                         Optional suppressDialogs As Boolean = False,
                                         Optional requireMainWindow As Boolean = True,
                                         Optional startProcessTimeout As Integer = 30,
                                         Optional createWindowTimeout As Integer = 15) As SldWorks

        Dim executablePath As String = CTFileSystem.GetSolidWorksExecutablePath(version)

        If File.Exists(executablePath) = False Then Return Nothing

        Dim info As ProcessStartInfo = New ProcessStartInfo(executablePath)

        If suppressDialogs Then info.Arguments = "/r"

        Dim process As Process = Process.Start(info)
        Dim app As SldWorks = Nothing
        Dim t As DateTime = DateTime.Now

        While app Is Nothing
            Threading.Thread.Sleep(1000)
            If Math.Abs(DateTime.Now.Subtract(t).Seconds) > startProcessTimeout Then Return Nothing

            'If it were possible to get a GUID from a process ID then we could use GetActiveObject instead of this
            app = GetComObjectFromProcessId(process.Id)
        End While

        t = DateTime.Now
        While IsRunning(isMainWindowCreated:=True) = False
            Threading.Thread.Sleep(1000)
            If Math.Abs(DateTime.Now.Subtract(t).Seconds) > createWindowTimeout Then Return Nothing
        End While

        If visible = False Then
            Dim frame As Frame = app.Frame()
            If frame Is Nothing Then Return app
            Dim handle As IntPtr = frame.GetHWndx64()
            If ShowWindow(handle, 0) Then Return app
        End If

        Return app
    End Function

我刚刚进行了测试,用起来比较简单。我用代码新建了两个solidworks 2018窗口:


        private SldWorks sldWorks2018_1 = null;
        private SldWorks sldWorks2018_2 = null;

        private void button1_Click(object sender, EventArgs e)
        {
            sldWorks2018_1 = PStandAlone.RunSolidWorks(26, true, false, false, 30, 15);
        }

        private void button2_Click(object sender, EventArgs e)
        {
            sldWorks2018_2 = PStandAlone.RunSolidWorks(26, true, false, false, 30, 15);
        }

        private void button3_Click(object sender, EventArgs e)
        {
            sldWorks2018_1.SendMsgToUser("From 2018 -1");
            sldWorks2018_2.SendMsgToUser("From 2018 -2");
        }

      

源码https://gitee.com/painezeng/PSWStandalone(vb.net)

posted @
2020-04-17 10:00 
painezeng  阅读(
250)  评论(
0
编辑 
收藏 
举报