C#如何实现动态添加右键菜单

C#如何实现动态添加右键菜单,第1张

这个貌似不难,右键菜单用代码生成就行了。

你是要用ContextMenuStrip控件,生成的菜单可以用代码控制。如

// This code example demonstrates how to handle the Opening event

// It also demonstrates dynamic item addition and dynamic

// SourceControl determination with reuse

class Form3 : Form

{

// Declare the ContextMenuStrip control

private ContextMenuStrip fruitContextMenuStrip;

public Form3()

{

// Create a new ContextMenuStrip control

fruitContextMenuStrip = new ContextMenuStrip();

// Attach an event handler for the

// ContextMenuStrip control's Opening event

fruitContextMenuStripOpening += new SystemComponentModelCancelEventHandler(cms_Opening);

// Create a new ToolStrip control

ToolStrip ts = new ToolStrip();

// Create a ToolStripDropDownButton control and add it

// to the ToolStrip control's Items collections

ToolStripDropDownButton fruitToolStripDropDownButton = new ToolStripDropDownButton("Fruit", null, null, "Fruit");

tsItemsAdd(fruitToolStripDropDownButton);

// Dock the ToolStrip control to the top of the form

tsDock = DockStyleTop;

// Assign the ContextMenuStrip control as the

// ToolStripDropDownButton control's DropDown menu

fruitToolStripDropDownButtonDropDown = fruitContextMenuStrip;

// Create a new MenuStrip control and add a ToolStripMenuItem

MenuStrip ms = new MenuStrip();

ToolStripMenuItem fruitToolStripMenuItem = new ToolStripMenuItem("Fruit", null, null, "Fruit");

msItemsAdd(fruitToolStripMenuItem);

// Dock the MenuStrip control to the top of the form

msDock = DockStyleTop;

// Assign the MenuStrip control as the

// ToolStripMenuItem's DropDown menu

fruitToolStripMenuItemDropDown = fruitContextMenuStrip;

// Assign the ContextMenuStrip to the form's

// ContextMenuStrip property

thisContextMenuStrip = fruitContextMenuStrip;

// Add the ToolStrip control to the Controls collection

thisControlsAdd(ts);

//Add a button to the form and assign its ContextMenuStrip

Button b = new Button();

bLocation = new SystemDrawingPoint(60, 60);

thisControlsAdd(b);

bContextMenuStrip = fruitContextMenuStrip;

// Add the MenuStrip control last

// This is important for correct placement in the z-order

thisControlsAdd(ms);

}

// This event handler is invoked when the ContextMenuStrip

// control's Opening event is raised It demonstrates

// dynamic item addition and dynamic SourceControl

// determination with reuse

void cms_Opening(object sender, SystemComponentModelCancelEventArgs e)

{

// Acquire references to the owning control and item

Control c = fruitContextMenuStripSourceControl as Control;

ToolStripDropDownItem tsi = fruitContextMenuStripOwnerItem as ToolStripDropDownItem;

// Clear the ContextMenuStrip control's Items collection

fruitContextMenuStripItemsClear();

// Check the source control first

if (c != null)

{

// Add custom item (Form)

fruitContextMenuStripItemsAdd("Source: " + cGetType()ToString());

}

else if (tsi != null)

{

// Add custom item (ToolStripDropDownButton or ToolStripMenuItem)

fruitContextMenuStripItemsAdd("Source: " + tsiGetType()ToString());

}

// Populate the ContextMenuStrip control with its default items

fruitContextMenuStripItemsAdd("-");

fruitContextMenuStripItemsAdd("Apples");

fruitContextMenuStripItemsAdd("Oranges");

fruitContextMenuStripItemsAdd("Pears");

// Set Cancel to false

// It is optimized to true based on empty entry

eCancel = false;

}

}

LightningChart的一个优点:在图中,通过鼠标滚轮,轻松实现放大缩小功能,便于观察曲线细节,下图为缩小放大效果:

绘制曲线的代码:

using System;using SystemCollectionsGeneric;using SystemComponentModel;using SystemData;using SystemDrawing;using SystemLinq;using SystemText;using SystemThreadingTasks;using SystemWindowsForms;//添加引用集using ArctionWinFormsCharting;using ArctionWinFormsChartingSeriesXY;

namespace WindowsFormsApplication5{public partial class Form1 : Form{public Form1(){InitializeComponent();}//画线方法private void PaintLine(){DataBaseOpe ope = new DataBaseOpe();//禁用属性改变引起的重画,以便更快的渲染lightningChartUltimate1BeginUpdate();//lightningChartUltimate1Dock = DockStyleFill;//添加点线系列PointLineSeries pls = new PointLineSeries(lightningChartUltimate1ViewXY,lightningChartUltimate1ViewXYXAxes[0],lightningChartUltimate1ViewXYYAxes[0]);//显示点plsPointsVisible = false;SeriesPoint[] aPoints = new SeriesPoint[1000];for (int iPoint = 0; iPoint < opeGetXmax() + 1; iPoint++){aPoints[iPoint]X = (double)iPoint;aPoints[iPoint]Y = opeGetYvalue(iPoint);}//为点线系列分配数据plsPoints = aPoints;//将点线系列添加进列表lightningChartUltimate1ViewXYPointLineSeriesAdd(pls);//允许Chart绘图lightningChartUltimate1EndUpdate();}

private void buttonGO_Click(object sender, EventArgs e){DataBaseOpe ope = new DataBaseOpe();PIDdeal pid = new PIDdeal();//LightningChart初始化lightningChartUltimate1ViewXYPointLineSeriesClear();//数据库初始化:清空数据库opeClearDataBase();//PID变量初始化pidPIDinit();pidSetValue = doubleParse(textBoxSetValueText);double p = doubleParse(textBoxKpText);double i = doubleParse(textBoxKiText);double d = doubleParse(textBoxKdText);for(int j = 0;j < 1000;j++){opeAddData(j, pidPIDcontrol(pidSetValue, p, i, d));}PaintLine();}}}

实现上面图中效果,需要用到数据库 *** 作和PID算法来实现,加上一个timer控件还可以实现实时曲线的绘制,

上图包含多种图表绘制的例子,可自定义实现数据可视化 *** 作。

(简数科技    技术支持      免费中文)

1 基本思想之什么是分库分表?

从字面上简单理解,就是把原本存储于一个库的数据分块存储到多个库上,把原本存储于一个表的数据分块存储到多个表上。

2 基本思想之为什么要分库分表?

据库中的数据量不一定是可控的,在未进行分库分表的情况下,随着时间和业务的发展,库中的表会越来越多,表中的数据量也会越来越大,相应地,数据 *** 作,增

删改查的开销也会越来越大;另外,由于无法进行分布式式部署,而一台服务器的资源(CPU、磁盘、内存、IO等)是有限的,最终数据库所能承载的数据量、

数据处理能力都将遭遇瓶颈。

3 分库分表的实施策略。

分库分表有垂直切分和水平切分两种。

31

何谓垂直切分,即将表按照功能模块、关系密切程度划分出来,部署到不同的库上。例如,我们会建立定义数据库workDB、商品数据库payDB、用户数据

库userDB、日志数据库logDB等,分别用于存储项目数据定义表、商品定义表、用户数据表、日志数据表等。

32

何谓水平切分,当一个表中的数据量过大时,我们可以把该表的数据按照某种规则,例如userID散列,进行划分,然后存储到多个结构相同的表,和不同的库

上。例如,我们的userDB中的用户数据表中,每一个表的数据量都很大,就可以把userDB切分为结构相同的多个userDB:part0DB、

part1DB等,再将userDB上的用户数据表userTable,切分为很多userTable:userTable0、userTable1等,

然后将这些表按照一定的规则存储到多个userDB上。

33 应该使用哪一种方式来实施数据库分库分表,这要看数据库中数据量的瓶颈所在,并综合项目的业务类型进行考虑。

如果数据库是因为表太多而造成海量数据,并且项目的各项业务逻辑划分清晰、低耦合,那么规则简单明了、容易实施的垂直切分必是首选。

如果数据库中的表并不多,但单表的数据量很大、或数据热度很高,这种情况之下就应该选择水平切分,水平切分比垂直切分要复杂一些,它将原本逻辑上属于一体

的数据进行了物理分割,除了在分割时要对分割的粒度做好评估,考虑数据平均和负载平均,后期也将对项目人员及应用程序产生额外的数据管理负担。

在现实项目中,往往是这两种情况兼而有之,这就需要做出权衡,甚至既需要垂直切分,又需要水平切分。我们的游戏项目便综合使用了垂直与水平切分,我们首先对数据库进行垂直切分,然后,再针对一部分表,通常是用户数据表,进行水平切分。

4 分库分表存在的问题。

41 事务问题。

在执行分库分表之后,由于数据存储到了不同的库上,数据库事务管理出现了困难。如果依赖数据库本身的分布式事务管理功能去执行事务,将付出高昂的性能代价;如果由应用程序去协助控制,形成程序逻辑上的事务,又会造成编程方面的负担。

42 跨库跨表的join问题。

在执行了分库分表之后,难以避免会将原本逻辑关联性很强的数据划分到不同的表、不同的库上,这时,表的关联 *** 作将受到限制,我们无法join位于不同分库的表,也无法join分表粒度不同的表,结果原本一次查询能够完成的业务,可能需要多次查询才能完成。

43 额外的数据管理负担和数据运算压力。

外的数据管理负担,最显而易见的就是数据的定位问题和数据的增删改查的重复执行问题,这些都可以通过应用程序解决,但必然引起额外的逻辑运算,例如,对于

一个记录用户成绩的用户数据表userTable,业务要求查出成绩最好的100位,在进行分表之前,只需一个order

by语句就可以搞定,但是在进行分表之后,将需要n个order

by语句,分别查出每一个分表的前100名用户数据,然后再对这些数据进行合并计算,才能得出结果。

MOE分子对接教程

1在MOE窗口open打开一个有小配体的蛋白(PDB或moe文件)点击Compute→prepare→Protonate3D(使质子化)点击OK。打开SEQ面板删去水分子和与小配体无关的其他杂配体或离子在MOE窗口右边点击SiteView点击System,改变配体颜色使得小配体显示绿色C骨架在MOE窗口点击Surface→recepter在MOE。

接下来对接一个小配体点击Compute→dock在Recepter选项选择Recepter+Solvent其它选择默认值。点击Run。在表单你会看到有不同的构象对接结果,包括RMSD值。

2创建一个药效团模型在MOE窗点Compute→Pharmacophore→QueryEditor点击R,这样会创建基于受体的药效团特征。点击口袋中显示的小球,然后点击feature,这样在对接口袋就会显示药效团。

3化合物数据库的对接关闭PharmacophoreQueryEditor面板在MOE窗口点Compute→DockOutput选项选择一个对接结果数据库名字,这里命名moe_dock2Receptor选项为Recepter+SolventLigand选项为MDBFile,选择要对接的pde5inhibitorsmdb(这里说明一下,mdb格式是MOE独有的,用的不多,但是可以将常用的sdf和mol2格式转化为mdb格式,方法为将sdf或mol2文件用MOE打开成表单。

这里,mol2topdbqs是为受体转化为pdbqs文件。一般来说,mol2是比较通用的文件格式。不过,由于autodock需要考虑受体的溶剂化效应,所以在autodock中用于对接的小分子需要pdbq与pdbqs格式。在autodock中有个程序为mol2topdbqs,可以直接转化mol2文件为pdbqs文件。

在不同运行平台,由于awk的版本不同,运行略有不同。

比如,在sgi irix中,直接使用mol2topdbqs命令就可以。这个其实是由两个命令构成的:

%mol2topdbq macromol2 > macropdbq

%addsol macropdbq macropdbqs

但是在linux中,这个命令提示出错。不过,这个命令分解为两个命令就可以:

$mol2fftopdbq macromol2 > macropdbq

$addsol macropdbq macropdbqs

对于小分子配体文件,要用deftors命令。

用法

$deftors ligmol2

会提示定义环,选1->c->c就可以了。

这是针对单个配体文件来说的,如果对于数据库中的多个小分子,就需要编写循环脚本批量 *** 作了。

nci-3d中有已经准备好的pdbq格式的小分子,可以直接用于autodock的对接。我想你可以参考他们的批量转化方法。

在autodock运行中,最占时间的是格点(grid)参数的计算。而每个小分子与受体作用的格点参数都是不同的。在JMC的两篇文章中(J Med Chem 2005, 48: 2308-2318;J Med Chem 2006, 49: 2417-2430),同一个课题组发表了两篇文章,主要是以P450酶为靶点,对autodock的源代码进行修改,使不同原子类型的格点参数计算一次完成,然后,不同的小分子可以随时调用计算好的格点参数用于对接。这样就解决了虚拟筛选中每个分子重复计算格点参数的速度问题。

在最近的一篇文章中(proteins,200665:549-554),一个韩国课题组发表文章,利用autodock进行虚拟筛选,文章没有对格点计算方法进行详述,不过据我推想,他们应该也采用了jmc两篇文章的方法。

jmc文章作者修改后的autodock源代码可以通过发邮件联系得到。同时,他们还通过修改源代码,实现了将水分子中氧上的氢键接受作用考虑在分子对接中(在原代码中,只能考虑水分子的氢键供体作用)。

上海药物所曾经在论坛中发过一段脚本,通过循环来利用autodock进行虚拟筛选。这个极有参考意义。不过脚本中需要对数据库中的每个小分子都计算格点能,这可能会使虚拟筛选时间大大延长。

首先,下载安装包,按照提示安装即可。注意安装的时候地址中不要含有中文,以免不可知的问题。安装好之后,在安装目录下找到adtbat,右键发送一个快捷方式到桌面。安装目录为:D:\Program Files (x86)\The Scripps Research Institute ,那么adtbat文件则位于D:\Program Files(x86)\The Scripps Research Institute\MGL下。为了后续方便,在E盘下创建一个工作目录E:\AutoDock。创建好之后,把MGLtools安装目录下的Autodock\426文件夹复制到工作目录中。然后,回到刚才创建的桌面快捷方式,右键,设置起始位置为E盘的工作目录E:\AutoDock,工作目录就设置完毕了。另外还需要Pymol软件查看3D结构,Open Babel用来将pdbqt文件转成pdb文件,便于查看,下载地址自行查找。受体和配体的pdb文件准备,以PDB数据库的3uf0为例,这是某个脱氢酶与NADP的复合物结构。先用Pymol软件将受体和配体分子的结构从3uf0中提取出来,分别保存为rpdb和nappdb。水分子已经在pymol软件中全都删除了。受体和配体的叫法不准确,但是为了方便,我就先这么称呼了。

通常遇到这样的问题是因为通过 App Store 更新或者下载应用时,可能会遇到下载进程卡住,应用无法继续下载,也无法从手机桌面上进行卸载。

若出现此类灰色的应用图标,在尝试重启设备之后,仍然无法继续下载也无法在桌面上进行删除,可以前往 iPhone 设置-通用-储存空间中查找是否有相关的项目,如果有进行删除。

如果在储存空间中也找不到相关内容,可以尝试如下办法:

1、更改系统语言,关闭掉所有应用和软件。重新打开 App Store,搜索对应的软件进行重新下载,下载完毕之后再换回原来的语言。

2、如果是在 App Store 中进行下载时出现此问题,可以尝试在电脑上打开爱思助手,在其中搜索对应的 App,连接手机,在手机上重新安装。

3、打开爱思助手 PC 端,并将手机连接到电脑,在爱思助手工具箱中找到删除顽固图标的功能,通过尝试此功能清除灰色图标之后,再重新下载应用。

请注意:如果设备在“设置-通用-iPhone存储空间”中开启了“卸载未使用应用”功能来优化存储空间,则删除顽固图标功能,会将这些应用的数据一并删除。

以上就是关于C#如何实现动态添加右键菜单全部的内容,包括:C#如何实现动态添加右键菜单、C#中如何利用LightningChart绘制曲线图表、数据库为什么要分库分表等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址: http://outofmemory.cn/sjk/9273379.html

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

发表评论

登录后才能评论

评论列表(0条)

保存