cfc程序整体下装注意事项

cfc程序整体下装注意事项,第1张

在进行 CFC 程序的整体安装前,需要注意以下几点:

1. 确认系统要求:CFC 程序需要在支持 Windows 7 及以上或者 Ubuntu 16.04 LTS 及以上版本的计算机上运行。

2. 下载安装程序:可以在 CFC 官网或者 Github 上下载最新版本的 CFC 安装程序,下载后可以通过校验程序的 MD5 值或者 SHA-256 值来验证文件完整性。

3. 关闭杀毒软件:在安装 CFC 程序之前,需要关闭计算机上的所有杀毒软件和防火墙,以避免安装过程中被误判为病毒或者受到阻止。

4. 确定安装路径:在安装 CFC 程序时,需要选择合适的安装路径,安装路径不能包含中文字符,同时需要保证安装路径有足够的可用空间。

5. 按照提示 *** 作:在安装 CFC 程序时,需要按照程序的提示进行 *** 作,如输入管理员权限、选择安装路径、设置数据目录等。

6. 设置初始密码:在启动 CFC 程序之前,需要设置初始密码,用于保护账户信息和资产安全。同时,需要牢记该密码,并将其妥善保管。

总之,在进行 CFC 程序的整体安装前,需要充分了解安装程序的要求和流程,并且谨慎 *** 作,以确保安装过程的顺利和安全。

C#实现类似的屏幕截图程序  VS2005

程序流程如下:

截取整个屏幕并保存

2.新开一个全屏窗口,将保存的屏幕作为背景

3.鼠标拖动改变截取范围,右键取消

4.双击截取,保存在粘贴板,全屏窗口关闭

代码部分

首先新建一个项目ScreenCutter,将窗体名改为MainForm,再新建一个窗体ScreenBody.

添加一个按钮btnCutter到ScreenCutter并添加按钮事件:

private void btnCutter_Click(object sender, EventArgs e)

{

Image img = new Bitmap(Screen.AllScreens[0].Bounds.Width, Screen.AllScreens[0].Bounds.Height)

Graphics g = Graphics.FromImage(img)

g.CopyFromScreen(new Point(0, 0), new Point(0, 0), Screen.AllScreens[0].Bounds.Size)

ScreenBody body = new ScreenBody()

body.BackgroundImage = img

body.Show()

}Screen.AllScreens[0]是获取当前所有设备窗口的第一个,我这里只有一个显示器,当然我就是第一个.

利用Graphics的CopyFromScreen函数获取当前屏幕.

好了,现在按下按钮全屏窗口就会出来了.

下面讲全屏窗口ScreenBody,首先设置窗体的FormBorderStyle为None,然后声明以下变量

private Graphics MainPainter //主画笔

private Pen pen              //就是笔咯

private bool isDowned        //判断鼠标是否按下

private bool RectReady        //矩形是否绘制完成

private Image baseImage      //基本图形(原来的画面)

private Rectangle Rect       //就是要保存的矩形

private Point downPoint       //鼠标按下的点

int tmpx                 

int tmpy

之后就是窗体的鼠标函数了,里面很多代码都没有作出整理,看了一下,整理后的代码应该会更少更精简的

private void ScreenBody_DoubleClick(object sender, EventArgs e)

{

if (((MouseEventArgs)e).Button == MouseButtons.Left Rect.Contains(((MouseEventArgs)e).X, ((MouseEventArgs)e).Y))

{

//保存的时候有很多种方法的我这里只用了这种

Image memory = new Bitmap(Rect.Width, Rect.Height)

Graphics g = Graphics.FromImage(memory)

g.CopyFromScreen(Rect.X + 1, Rect.Y + 1, 0, 0, Rect.Size)

Clipboard.SetImage(memory)

this.Close()

}

}

private void ScreenBody_MouseDown(object sender, MouseEventArgs e)

{

if (e.Button == MouseButtons.Left)

{

isDowned = true

if (RectReady == false)

{

Rect.X = e.X

Rect.Y = e.Y

downPoint = new Point(e.X, e.Y)

}

if (RectReady == true)

{

tmpx = e.X

tmpy = e.Y

}

}

if (e.Button == MouseButtons.Right)

{

if (RectReady != true)

{

this.Close()

return

}

MainPainter.DrawImage(baseImage, 0, 0)

RectReady = false

}

}

private void ScreenBody_MouseUp(object sender, MouseEventArgs e)

{

if (e.Button == MouseButtons.Left)

{

isDowned = false

RectReady = true

}

}

private void ScreenBody_MouseMove(object sender, MouseEventArgs e)

{

if (RectReady == false)

{

if (isDowned == true)

{

Image New = DrawScreen((Image)baseImage.Clone(), e.X, e.Y)

MainPainter.DrawImage(New, 0, 0)

New.Dispose()

}

}

if (RectReady == true)

{

if (Rect.Contains(e.X, e.Y))

{

//this.Cursor = Cursors.Hand

if (isDowned == true)

{

//和上一次的位置比较获取偏移量

Rect.X = Rect.X + e.X - tmpx

Rect.Y = Rect.Y + e.Y - tmpy

//记录现在的位置

tmpx = e.X

tmpy = e.Y

MoveRect((Image)baseImage.Clone(), Rect)

}

}

}

}

private void ScreenBody_Load(object sender, EventArgs e)

{

this.WindowState = FormWindowState.Maximized

MainPainter = this.CreateGraphics()

pen = new Pen(Brushes.Blue)

isDowned = false

baseImage = this.BackgroundImage

Rect = new Rectangle()

RectReady = false

}

辅助函数

本来应该写更多的辅助函数的,将窗体响应函数里面的代码放到里面来,不过本人很懒,就这样将就了.呵呵

private void DrawRect(Graphics Painter, int Mouse_x, int Mouse_y)

{

int width = 0

int heigth = 0

if (Mouse_y ltRect.Y)

{

Rect.Y = Mouse_y

heigth = downPoint.Y - Mouse_y

}

else

{

heigth = Mouse_y - downPoint.Y

}

if (Mouse_x ltRect.X)

{

Rect.X = Mouse_x

width = downPoint.X - Mouse_x

}

else

{

width = Mouse_x - downPoint.X

}

Rect.Size = new Size(width, heigth)

Painter.DrawRectangle(pen, Rect)

}

private Image DrawScreen(Image back, int Mouse_x, int Mouse_y)

{

Graphics Painter = Graphics.FromImage(back)

DrawRect(Painter, Mouse_x, Mouse_y)

return back

}

private void MoveRect(Image image, Rectangle Rect)

{

Graphics Painter = Graphics.FromImage(image)

Painter.DrawRectangle(pen, Rect.X, Rect.Y, Rect.Width, Rect.Height)

DrawRects(Painter)

MainPainter.DrawImage(image, 0, 0)

image.Dispose()

}

施耐德中上升沿是R_TRIG,下降沿是F_TRIG。上升沿触点就是相应点信号在由0变1时动作,下降沿触点就是相应点信号在由1变0时动作。不管是什么PLC,上升沿和下降沿的用法都是一样的。你可以做个实验,接个开关至X0点,把下面的程序写进PLC监控运行一下,按住X0不放。LDX0INCD0你会发现计数器一直在计数LDPX0INCD10而这个只会计数1次LDFX0INCD20。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/8111951.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-13
下一篇2023-04-13

发表评论

登录后才能评论

评论列表(0条)

    保存