返回顶部
首页 > 资讯 > 精选 >C#如何实现chart控件动态曲线绘制
  • 516
分享到

C#如何实现chart控件动态曲线绘制

2023-06-29 05:06:39 516人浏览 泡泡鱼
摘要

这篇文章将为大家详细讲解有关C#如何实现chart控件动态曲线绘制,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体内容如下思想实验室要做一个动态曲线绘制,网上方法很多,但是缺乏完整代码和效果图的整合,往

这篇文章将为大家详细讲解有关C#如何实现chart控件动态曲线绘制,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

具体内容如下

思想

实验室要做一个动态曲线绘制,网上方法很多,但是缺乏完整代码和效果图的整合,往往总是缺少其一,因此整理如下,方便大家编程,节约时间。
思路:新建一个队列,利用timer控件,动态的往队列中加入数据,每次触发事件,就相当于将队列中的值全部重新画一遍。

我的目的是做四个点的动态监测,所以代码重复了四次,其实应该用4个线程来做,思路就显得较为清晰了,这也是可以改进的地方。

public partial class 界面_Xtratabcontrol版本_ : FORM    {        private Queue<double> dataQueue1 = new Queue<double>(100); //30个就清空一次        private Queue<double> dataQueue2 = new Queue<double>(100); //30个就清空一次        private Queue<double> dataQueue3 = new Queue<double>(100); //30个就清空一次        private Queue<double> dataQueue4 = new Queue<double>(100); //30个就清空一次        private int stress1 = 0;//设置一个压力值全局变量        private int stress2 = 0;//设置一个压力值全局变量        private int stress3 = 0;//设置一个压力值全局变量        private int stress4 = 0;//设置一个压力值全局变量        string monthNow = "";        string monthNext = "";        string currentTime = "";        bool isRefresh = false;        public 界面_Xtratabcontrol版本_()        {            InitializeComponent();            dataGridView1.AutoGenerateColumns = false; //设置不自动显示数据库中未绑定的列            //设置隔行背景色            this.dataGridView1.RowsDefaultCellStyle.BackColor = Color.Bisque;            this.dataGridView1.AlternatingRowsDefaultCellStyle.BackColor = Color.Beige;        }        private void btnInit_Click(object sender, EventArgs e)        {            InitChart1();            InitChart2();            InitChart3();            InitChart4();        }        private void btnStart_Click(object sender, EventArgs e)        {            this.timer1.Start();        }        private void btnStop_Click(object sender, EventArgs e)        {            this.timer1.Stop();        }        private void timer1_Tick(object sender, EventArgs e)        {            try            {                UpdateDate(); //根据当前时间取下一个数据,同时给month赋值                dataQueue1.Enqueue(stress1); //就是这,不断往里面加数据。                dataQueue2.Enqueue(stress2);                dataQueue3.Enqueue(stress3);                dataQueue4.Enqueue(stress4);                if (isRefresh)                {                    //刷新界面                    isRefresh = false;                    InitChart1();                    InitChart2();                    InitChart3();                    InitChart4();                    dataQueue1.Enqueue(stress1);                    dataQueue2.Enqueue(stress2);                    dataQueue3.Enqueue(stress3);                    dataQueue4.Enqueue(stress4);                }                this.chart1.Series[0].Points.Clear();                this.chart2.Series[0].Points.Clear();                this.chart3.Series[0].Points.Clear();                this.chart4.Series[0].Points.Clear();                for (int i = 0; i < dataQueue1.Count; i++)                {                    this.chart1.Series[0].Points.AddXY((i + 1), dataQueue1.ElementAt(i)); 相当于每次都是重新画一遍                }                for (int i = 0; i < dataQueue2.Count; i++)                {                    this.chart2.Series[0].Points.AddXY((i + 1), dataQueue2.ElementAt(i)); 相当于每次都是重新画一遍                }                for (int i = 0; i < dataQueue3.Count; i++)                {                    this.chart3.Series[0].Points.AddXY((i + 1), dataQueue3.ElementAt(i)); 相当于每次都是重新画一遍                }                for (int i = 0; i < dataQueue4.Count; i++)                {                    this.chart4.Series[0].Points.AddXY((i + 1), dataQueue4.ElementAt(i)); 相当于每次都是重新画一遍                }            }            catch (Exception ex)            {                MessageBox.Show(ex.Message);            }        }        private void InitChart1()        {            try            {                //定义图表区域                this.chart1.ChartAreas.Clear();                ChartArea chartArea1 = new ChartArea("C1");                this.chart1.ChartAreas.Add(chartArea1);                //this.chart1.Dock = DockStyle.Fill;                //定义存储和显示点的容器                this.chart1.Series.Clear();                Series series1 = new Series("S1");                series1.ChartArea = "C1";                this.chart1.Series.Add(series1);                //设置图表显示样式                this.chart1.ChartAreas[0].AxisY.Minimum = 30000;                this.chart1.ChartAreas[0].AxisY.Maximum = 50000;                this.chart1.ChartAreas[0].AxisX.Minimum = 1;                this.chart1.ChartAreas[0].AxisX.Maximum = 31;                this.chart1.ChartAreas[0].AxisX.Interval = 1;                this.chart1.ChartAreas[0].AxisX.MajorGrid.LineColor = System.Drawing.Color.Silver;                this.chart1.ChartAreas[0].AxisY.MajorGrid.LineColor = System.Drawing.Color.Silver;                //设置标题                this.chart1.Titles.Clear();                this.chart1.Titles.Add("S01");                this.chart1.Titles[0].Text = "1号监测点";                this.chart1.Titles[0].ForeColor = Color.RoyalBlue;                this.chart1.Titles[0].Font = new System.Drawing.Font("Microsoft Sans Serif", 12F);                //设置图表显示样式                this.chart1.Series[0].Color = Color.Red;                if (rb1.Checked)                {                    //this.chart1.Titles[0].Text = string.Format("动态 {0} 显示", rb1.Text);                    this.chart1.Titles[0].Text = string.Format("1号监测点");                    this.chart1.Series[0].ChartType = SeriesChartType.Line;                }                if (rb2.Checked)                {                    this.chart1.Titles[0].Text = string.Format("动态 {0} 显示", rb1.Text);                    this.chart1.Series[0].ChartType = SeriesChartType.Spline;                }                this.chart1.Series[0].Points.Clear();                //DBEngine.ConnectDB("orcl", "dt", "6312");                dataQueue1.Clear();//清空队列中所有数据            }            catch (Exception ex)            {            }        }        private void InitChart2()        {            try            {                //定义图表区域                this.chart2.ChartAreas.Clear();                ChartArea chartArea2 = new ChartArea("C2");                this.chart2.ChartAreas.Add(chartArea2);                //this.chart1.Dock = DockStyle.Fill;                //定义存储和显示点的容器                this.chart2.Series.Clear();                Series series2 = new Series("S2");                series2.ChartArea = "C2";                this.chart2.Series.Add(series2);                //设置图表显示样式                this.chart2.ChartAreas[0].AxisY.Minimum = 30000;                this.chart2.ChartAreas[0].AxisY.Maximum = 50000;                this.chart2.ChartAreas[0].AxisX.Minimum = 1;                this.chart2.ChartAreas[0].AxisX.Maximum = 31;                this.chart2.ChartAreas[0].AxisX.Interval = 1;                this.chart2.ChartAreas[0].AxisX.MajorGrid.LineColor = System.Drawing.Color.Silver;                this.chart2.ChartAreas[0].AxisY.MajorGrid.LineColor = System.Drawing.Color.Silver;                //设置标题                this.chart2.Titles.Clear();                this.chart2.Titles.Add("S02");                this.chart2.Titles[0].Text = "动态折线图显示";                this.chart2.Titles[0].ForeColor = Color.RoyalBlue;                this.chart2.Titles[0].Font = new System.Drawing.Font("Microsoft Sans Serif", 12F); //标题字体                //设置图表显示样式                this.chart2.Series[0].Color = Color.Red;                if (rb1.Checked)                {                    //this.chart2.Titles[0].Text = string.Format("动态 {0} 显示", rb1.Text);                    this.chart2.Titles[0].Text = string.Format("2号监测点");                    this.chart2.Series[0].ChartType = SeriesChartType.Line;                }                if (rb2.Checked)                {                    this.chart2.Titles[0].Text = string.Format("动态 {0} 显示", rb1.Text);                    this.chart2.Series[0].ChartType = SeriesChartType.Spline;                }                this.chart2.Series[0].Points.Clear();                //DBEngine.ConnectDB("orcl", "dt", "6312");                dataQueue2.Clear();//清空队列中所有数据            }            catch (Exception ex)            {            }        }        private void InitChart3()        {            try            {                //定义图表区域                this.chart3.ChartAreas.Clear();                ChartArea chartArea3 = new ChartArea("C3");                this.chart3.ChartAreas.Add(chartArea3);                //this.chart1.Dock = DockStyle.Fill;                //定义存储和显示点的容器                this.chart3.Series.Clear();                Series series3 = new Series("S3");                series3.ChartArea = "C3";                this.chart3.Series.Add(series3);                //设置图表显示样式                this.chart3.ChartAreas[0].AxisY.Minimum = 30000;                this.chart3.ChartAreas[0].AxisY.Maximum = 50000;                this.chart3.ChartAreas[0].AxisX.Minimum = 1;                this.chart3.ChartAreas[0].AxisX.Maximum = 31;                this.chart3.ChartAreas[0].AxisX.Interval = 1;                this.chart3.ChartAreas[0].AxisX.MajorGrid.LineColor = System.Drawing.Color.Silver;                this.chart3.ChartAreas[0].AxisY.MajorGrid.LineColor = System.Drawing.Color.Silver;                //设置标题                this.chart3.Titles.Clear();                this.chart3.Titles.Add("S03");                this.chart3.Titles[0].Text = "动态折线图显示";                this.chart3.Titles[0].ForeColor = Color.RoyalBlue;                this.chart3.Titles[0].Font = new System.Drawing.Font("Microsoft Sans Serif", 12F); //标题字体                //设置图表显示样式                this.chart3.Series[0].Color = Color.Red;                if (rb1.Checked)                {                    //this.chart3.Titles[0].Text = string.Format("动态 {0} 显示", rb1.Text);                    this.chart3.Titles[0].Text = string.Format("3号监测点");                    this.chart3.Series[0].ChartType = SeriesChartType.Line;                }                if (rb2.Checked)                {                    this.chart3.Titles[0].Text = string.Format("动态 {0} 显示", rb1.Text);                    this.chart3.Series[0].ChartType = SeriesChartType.Spline;                }                this.chart3.Series[0].Points.Clear();                //DBEngine.ConnectDB("orcl", "dt", "6312");                dataQueue3.Clear();//清空队列中所有数据            }            catch (Exception ex)            {            }        }        private void InitChart4()        {            try            {                //定义图表区域                this.chart4.ChartAreas.Clear();                ChartArea chartArea4 = new ChartArea("C4");                this.chart4.ChartAreas.Add(chartArea4);                //this.chart1.Dock = DockStyle.Fill;                //定义存储和显示点的容器                this.chart4.Series.Clear();                Series series4 = new Series("S4");                series4.ChartArea = "C4";                this.chart4.Series.Add(series4);                //设置图表显示样式                this.chart4.ChartAreas[0].AxisY.Minimum = 30000;                this.chart4.ChartAreas[0].AxisY.Maximum = 50000;                this.chart4.ChartAreas[0].AxisX.Minimum = 1;                this.chart4.ChartAreas[0].AxisX.Maximum = 31;                this.chart4.ChartAreas[0].AxisX.Interval = 1;                this.chart4.ChartAreas[0].AxisX.MajorGrid.LineColor = System.Drawing.Color.Silver;                this.chart4.ChartAreas[0].AxisY.MajorGrid.LineColor = System.Drawing.Color.Silver;                //设置标题                this.chart4.Titles.Clear();                this.chart4.Titles.Add("S04");                this.chart4.Titles[0].Text = "动态折线图显示";                this.chart4.Titles[0].ForeColor = Color.RoyalBlue;                this.chart4.Titles[0].Font = new System.Drawing.Font("Microsoft Sans Serif", 12F); //标题字体                //设置图表显示样式                this.chart4.Series[0].Color = Color.Red;                if (rb1.Checked)                {                    //this.chart4.Titles[0].Text = string.Format("动态 {0} 显示", rb1.Text);                    this.chart4.Titles[0].Text = string.Format("4号监测点");                    this.chart4.Series[0].ChartType = SeriesChartType.Line;                }                if (rb2.Checked)                {                    this.chart4.Titles[0].Text = string.Format("动态 {0} 显示", rb1.Text);                    this.chart4.Series[0].ChartType = SeriesChartType.Spline;                }                this.chart4.Series[0].Points.Clear();                //DBEngine.ConnectDB("orcl", "dt", "6312");                dataQueue4.Clear();//清空队列中所有数据            }            catch (Exception ex)            {            }        }        private void UpdateDate()        {            //1 2 3 4号点同时更新            try            {                //获取当前时间的batch值,将batch+1的时间值提取显示。                string selectsql = string.Format("select * from stressinfo where operatetime=to_date('{0}','yyyy-mm-dd')", dtp1.Value.ToShortDateString());                DataTable dtDate = new DataTable();                dtDate = DBEngine.GetDataTableBySql(selectsql);                if (dtDate.Rows.Count > 0) //4条                {                    string[] getmonthNow = dtp1.Value.ToShortDateString().Split('/'); //有的电脑是'-'                    monthNow = getmonthNow[1];                    int currentBatch = DBEngine.ObjToInt(dtDate.Rows[0]["batchnum"]);                    //int currentnode = DBEngine.ObjToInt(dtDate.Rows[0]["NODE"]); //当前节点和当前批次确定唯一记录                    currentBatch++;                    //获取下一个显示的时间值以及应力值                    string nextsql1 = string.Format("select * from stressinfo where batchnum='{0}' and node=1", currentBatch);                    DataTable dtNext1 = new DataTable();                    dtNext1 = DBEngine.GetDataTableBySql(nextsql1);//取得了下一个批次的所有应力监测点数据。                    if (dtNext1.Rows.Count > 0)                    {                        stress1 = DBEngine.ObjToInt(dtNext1.Rows[0]["CURRENTSTRESS"]);                        dtp1.Value = DBEngine.ObjToDateTime(dtNext1.Rows[0]["OPERATETIME"]); //日期显示(之后应该还有各点应力的提取)                        currentTime = dtp1.Value.ToShortDateString();                        string[] datetime = currentTime.Split('/');                        monthNext = datetime[1];                        if (monthNow != monthNext)                            isRefresh = true;                    }                    else                    {                        timer1.Stop();//数据到头了,没有数据了,batch+1找不到了                        btnStop.Focus(); //停止键焦点显示                    }                    ///第二个点,不用更新数据                    string nextsql2 = string.Format("select * from stressinfo where batchnum='{0}' and node=2", currentBatch);                    DataTable dtNext2 = new DataTable();                    dtNext2 = DBEngine.GetDataTableBySql(nextsql2);//取得了下一个批次的所有应力监测点数据。                    if (dtNext2.Rows.Count > 0)                    {                        stress2 = DBEngine.ObjToInt(dtNext2.Rows[0]["CURRENTSTRESS"]);                    }                    else                    {                        timer1.Stop();//数据到头了,没有数据了,batch+1找不到了                        btnStop.Focus(); //停止键焦点显示                    }                    ///第三个点,不用更新数据                    string nextsql3 = string.Format("select * from stressinfo where batchnum='{0}' and node=3", currentBatch);                    DataTable dtNext3 = new DataTable();                    dtNext3 = DBEngine.GetDataTableBySql(nextsql3);//取得了下一个批次的所有应力监测点数据。                    if (dtNext3.Rows.Count > 0)                    {                        stress3 = DBEngine.ObjToInt(dtNext3.Rows[0]["CURRENTSTRESS"]);                    }                    else                    {                        timer1.Stop();//数据到头了,没有数据了,batch+1找不到了                        btnStop.Focus(); //停止键焦点显示                    }                    ///第四个点,不用更新数据                    string nextsql4 = string.Format("select * from stressinfo where batchnum='{0}' and node=4", currentBatch);                    DataTable dtNext4 = new DataTable();                    dtNext4 = DBEngine.GetDataTableBySql(nextsql4);//取得了下一个批次的所有应力监测点数据。                    if (dtNext4.Rows.Count > 0)                    {                        stress4 = DBEngine.ObjToInt(dtNext4.Rows[0]["CURRENTSTRESS"]);                    }                    else                    {                        timer1.Stop();//数据到头了,没有数据了,batch+1找不到了                        btnStop.Focus(); //停止键焦点显示                    }                }            }            catch            {            }        }}

因为涉及到一些业务,有些代码没有粘,数据是和oracle数据库进行交互的,类文件名DBEngine.cs,大家自己做的时候别忘连接数据库,最终效果图

C#如何实现chart控件动态曲线绘制

关于“C#如何实现chart控件动态曲线绘制”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: C#如何实现chart控件动态曲线绘制

本文链接: https://lsjlt.com/news/322724.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C#如何实现chart控件动态曲线绘制
    这篇文章将为大家详细讲解有关C#如何实现chart控件动态曲线绘制,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体内容如下思想实验室要做一个动态曲线绘制,网上方法很多,但是缺乏完整代码和效果图的整合,往...
    99+
    2023-06-29
  • C#实现chart控件动态曲线绘制
    本文实例为大家分享了C#实现chart控件动态曲线绘制的具体代码,供大家参考,具体内容如下 思想 实验室要做一个动态曲线绘制,网上方法很多,但是缺乏完整代码和效果图的整合,往往总是缺...
    99+
    2024-04-02
  • Android实现动态曲线绘制
    我们在安卓开发中,有时会用到统计图表的功能,而曲线绘制是其中比较典型的一种,一般是利用给定的坐标点集和安卓自带的绘图模块进行绘制,直接得到的是一张完整的静态的曲线图。但有时,我们需要...
    99+
    2024-04-02
  • Matplotlib如何绘制动态实时曲线
    这篇文章主要为大家展示了“Matplotlib如何绘制动态实时曲线”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Matplotlib如何绘制动态实时曲线”这篇文章吧。很多时候,我们需要实时的绘制...
    99+
    2023-06-15
  • Android怎么实现动态曲线绘制
    这篇文章主要介绍了Android怎么实现动态曲线绘制的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Android怎么实现动态曲线绘制文章都会有所收获,下面我们一起来看看吧。我们在安卓开发中,有时会用到统计图表的...
    99+
    2023-07-02
  • C#动态绘制多条曲线的方法
    本文实例为大家分享了C#动态绘制多条曲线的具体代码,供大家参考,具体内容如下 实时绘制多条曲线,纵轴为数值,横轴为时间,精确到毫秒 实现效果如下: 代码: using System...
    99+
    2024-04-02
  • C语言如何实现绘制LoveBeat爱心曲线
    这篇文章主要讲解了“C语言如何实现绘制LoveBeat爱心曲线”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言如何实现绘制LoveBeat爱心曲线”吧!心形曲线给出心形曲线参数方程如下:...
    99+
    2023-07-05
  • echarts如何实现动态曲线图(多条曲线)
    目录echarts动态曲线图(多条曲线)HTML部分CSS部分JS部分echarts动态曲线图(多条曲线) ECharts是一个由百度开发的开源数据可视化工具,能够提供直观,生动,可...
    99+
    2022-11-13
    echarts 曲线图 echarts动态曲线图 echarts多条曲线
  • python多线程实现动态图绘制
    目录一、背景二、步骤1、使用matplotlib绘制动态图2、创建一个线程用于更新数据三、代码框架一、背景 有些情况下,我们面对实时更新的数据,希望能够在一个窗口中可视化出来,并且能...
    99+
    2024-04-02
  • Vue+Echarts实现绘制动态折线图
    目录1 引入Echarts1.1 安装1.2 引入1.3 基本使用2 动态折线图2.1 基本折线图2.2 动态折线图补充1 引入Echarts 1.1 安装 使用如下命令通过 npm...
    99+
    2023-03-19
    Vue Echarts绘制动态折线图 Vue Echarts绘制折线图 Vue Echarts 折线图 Vue Echarts
  • 关于Matplotlib绘制动态实时曲线的方法改进指南
    很多时候,我们需要实时的绘制曲线,如实时的绘制串口接收到的数据。最先想到的解决策略是类似于Matlab种的drawnow函数。 在python中Matplotlib库有着和Matla...
    99+
    2024-04-02
  • WPF+ASP.NETSignalR实现动态折线图的绘制
    目录什么是SignalRSignalR做了什么封装与集成SignalR用途官方网址和源码示例截图服务端项目创建SignalR服务端业务集成SignalR服务端配置客户端项目创建客户端...
    99+
    2023-01-03
    WPF 动态折线图 WPF 折线图 WPF SignalR 折线图
  • 详解Flutter如何绘制曲线,折线图及波浪动效
    目录正弦曲线绘制波浪动效曲线绘制折线图其他说明总结简介 上一篇用 Flutter 的 Canvas 画点有趣的图形我们介绍了使用 CustomPaint 绘制自定义形状,可以看到有了...
    99+
    2024-04-02
  • C语言实现在控制台打印余弦曲线
    目录需求 实例代码运行结果代码分析补充需求 在控制台打印余弦曲线。 余弦曲线又叫余弦波(cosinwave),是一种来自数学三角函数中的余弦比例的曲线。也是模拟信号的代表,...
    99+
    2023-02-16
    C语言打印余弦曲线 C语言余弦曲线 C语言 曲线
  • python多线程怎么实现动态图绘制
    今天小编给大家分享一下python多线程怎么实现动态图绘制的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、背景有些情况下,...
    99+
    2023-06-30
  • C语言如何实现绘制绕线画
    本篇内容介绍了“C语言如何实现绘制绕线画”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!绕线画简介简单点来说,就是在木板上钉一圈钉子,通过绕线...
    99+
    2023-07-04
  • C语言实现绘制LoveBeat爱心曲线的示例代码
    目录心形曲线曲线内点的生成曲线外点的生成制作动画示例代码心形曲线 给出心形曲线参数方程如下: x = sin^3(θ) y = (13 * cos(θ) - ...
    99+
    2023-03-08
    C语言实现绘制爱心曲线 C语言绘制爱心曲线 C语言 爱心曲线 C语言 曲线
  • HTML5中Canvas如何实现3D动态Chart图表
    小编给大家分享一下HTML5中Canvas如何实现3D动态Chart图表,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!动态效果图如下:这个例子用 HT 实现真的很容易,首先创建一个 HT ...
    99+
    2024-04-02
  • 如何在CSS中绘制曲线图形及展示动画
    目录理解 box-shadow使用阴影复制图像/投影图像在阴影坐标中运用三角函数三角函数如何在 CSS 中使用三角函数 sin/cos控制颜色及初始方向控制颜色在 css-doodl...
    99+
    2024-04-02
  • OpenGL 实践中如何进行贝塞尔曲线绘制
    这篇文章给大家介绍OpenGL 实践中如何进行贝塞尔曲线绘制,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。说到贝塞尔曲线,大家肯定都不陌生,网上有很多关于介绍和理解贝塞尔曲线的优秀文章和动态图。以下两个是比较经典的动图...
    99+
    2023-06-04
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作