主頁(yè) > 知識(shí)庫(kù) > asp.net中資源文件的使用

asp.net中資源文件的使用

熱門標(biāo)簽:山西防封卡電銷卡套餐 地圖標(biāo)注多個(gè)行程 廈門商鋪地圖標(biāo)注 云南外呼電銷機(jī)器人系統(tǒng) 浙江外呼系統(tǒng)怎么安裝 海外地圖標(biāo)注門市標(biāo) 上海楊浦怎么申請(qǐng)申請(qǐng)400電話 銅川小型外呼系統(tǒng)運(yùn)營(yíng)商 陜西人工外呼系統(tǒng)哪家好

其中,資源是的范圍很廣,它可由多種元素組成,包括與用戶交互的界面元素(如位圖、圖標(biāo)或光標(biāo))、應(yīng)用程序所需數(shù)據(jù)的自定義文件以及安裝 API 使用的版本文件、菜單和對(duì)話框等都可以作為資源。為.Net程序集添加資源,就可實(shí)現(xiàn)資源重用等功能。使用Visual Studio.Net集成開(kāi)發(fā)環(huán)境IDE很容易創(chuàng)建資源文件,把資源添加到工程中的方法和添加窗體、類庫(kù)一樣簡(jiǎn)單,只是你需要設(shè)置資源的“BuildAction”屬性為“Embedded Resource”,這樣你就可以使用這些資源
創(chuàng)建資源
字符串表是極常見(jiàn)的一種資源。要?jiǎng)?chuàng)建這類資源文件,有以下兩種方式:
(1)使用.Net命令行工具ResGen創(chuàng)建。首先創(chuàng)建包含資源內(nèi)容的文本文件,可使用(記事本、EditPlus等文本編輯器)。該文本文件由所需要的“鍵值對(duì)”組成,鍵的名稱可以在程序中引用,設(shè)置鍵名后把字符串值賦予該鍵即可完成文件的創(chuàng)建。作為示例,以下語(yǔ)句段產(chǎn)生這樣的資源,按下面的格式保存為userinfo.txt文件:

復(fù)制代碼 代碼如下:

Username="Songh";
Sex="Boy";
Birthday="1973-01-15";
Salary="5000RMB";

然后,把文本文件轉(zhuǎn)換為資源文件,這仍然通過(guò)ResGen工具來(lái)實(shí)現(xiàn)。執(zhí)行以下語(yǔ)句:ResGen userinfo.txt,就將生成資源文件userinfo.resources。另外,ResGen還可以創(chuàng)建基于XML格式的.resX資源文件,執(zhí)行以下命令ResGen userinfo.resources userinfo.resx 就將生成Xml格式的資源userinfo.resx。不過(guò),ResGen工具不支持圖象資源的操作,下面的方法就不具有這樣的限制。
(2)使用ResourceWriter類。 為易于創(chuàng)建資源文件,.Net結(jié)構(gòu)提供了ResourceWriter類以支持圖象等各種資源類型的創(chuàng)建。ResourceWriter類包含的方法能以系統(tǒng)默認(rèn)的格式將資源寫(xiě)入輸出文件或輸出流。與方法1)不同的是,這里統(tǒng)一在一個(gè)過(guò)程中完成。
要?jiǎng)?chuàng)建一個(gè)資源文件,請(qǐng)調(diào)用ResourceWriter類的構(gòu)造函數(shù)初始化類實(shí)例并至少提供流名或文件名。資源的實(shí)際內(nèi)容通過(guò)調(diào)用AddResource方法來(lái)完成,AddResource方法將資源指定為名稱和值對(duì)。資源的實(shí)際寫(xiě)入需要調(diào)用Generate方法來(lái)實(shí)現(xiàn),不過(guò),在調(diào)用Close方法關(guān)閉該ResourceWriter時(shí)將隱式調(diào)用Generate方法。
ResourceWriter.AddResource()方法向要寫(xiě)入資源的列表中添加資源。在創(chuàng)建ResourceWriter類實(shí)例后,該方法可以添加至多2GB的資源,下面的重載方法之一用于向資源列表中添加string資源:
復(fù)制代碼 代碼如下:

public void AddResource(
string name,//鍵名
string value//值
);

在這里,AddResource方法的第一個(gè)參數(shù)指定鍵名稱,第二個(gè)參數(shù)指定值。多次調(diào)用該方法就可以完成字符串表的創(chuàng)建。另外,添加圖象資源可以通過(guò)實(shí)例化類Image來(lái)實(shí)現(xiàn)(這時(shí),請(qǐng)?zhí)砑覵ystem.Drawing名稱空間)。
下面的代碼段生成包含字符串表和圖象的資源文件userinfo.resources。
復(fù)制代碼 代碼如下:

using System;
using System.Resources;
using System.Drawing;
public class RS
{
public static void Main()
{
ResourceWriter rw=new
ResourceWriter("userinfo.resources");//提供文件名以初始化ResourceWriter類實(shí)例。
Image image=Image.FromFile("photo.gif");//實(shí)例化Image類
rw.AddResource("Photo",image);//添加圖象
rw.AddResource("Username","songh");//添加字符串
rw.AddResource("Sex","boy");//添加字符串
rw.AddResource("Birthday","1973-01-15");//添加字符串
rw.AddResource("Salary","5000RMB");//添加字符串
rw.Close();//關(guān)閉ResourceWriter并隱式調(diào)用Generate()方法完成資源文件寫(xiě)入磁盤文件。
}
}

上面的代碼首先打開(kāi)圖形文件photo.gif,創(chuàng)建一個(gè)Image對(duì)象。這樣做時(shí),這個(gè)圖形文件必須存在于工程可執(zhí)行文件的目錄(通常是項(xiàng)目的\Bin\Debug目錄)下,或者在Image.FromFile()的方法參數(shù)中指定圖象的完整路徑。然后,通過(guò)幾次調(diào)用AddResouce()方法把字符串資源添加到ResourceWriter對(duì)象中。最后,調(diào)用Close()方法關(guān)閉ResourceWriter對(duì)象并隱式調(diào)用Generate()方法把資源寫(xiě)入文件userinfo.resources。
編譯以上代碼并運(yùn)行就將創(chuàng)建資源文件userinfo.resources。
以上兩種方式生成的資源文件均可以作為一個(gè)外部文件添加到程序集中,或者內(nèi)嵌到Dll或exe中。下面繼續(xù)說(shuō)明如何在Windows應(yīng)用程序使用資源文件。
使用資源文件
使用Visual Studio.Net集成開(kāi)發(fā)環(huán)境IDE,可以把很容易把資源文件添加到程序集中。只需要在創(chuàng)建的工程中添加已經(jīng)存在的資源文件,簡(jiǎn)單設(shè)置其屬性就可將資源文件嵌入該程序集。下面通過(guò)一個(gè)C# Windows控制臺(tái)實(shí)例來(lái)說(shuō)明任何使用上面創(chuàng)建的userinfo.resources資源文件。
首先,創(chuàng)建C# Windows Console項(xiàng)目ResourceUserinfo,打開(kāi)"項(xiàng)目\添加現(xiàn)有項(xiàng)",找到前面創(chuàng)建的資源文件Userinfo.resources添加到這個(gè)工程中;
然后,選擇這個(gè)資源文件,將屬性BuildAction(生成操作)設(shè)置為Embedded Resource(嵌入的資源),這樣,資源文件就可以嵌入到輸出的程序集中。
現(xiàn)在,你可以使用這個(gè)資源文件了。System.Resources名稱空間中的ResourceManager類提供在運(yùn)行時(shí)方便地訪問(wèn)特定資源的途徑。具體地可以通過(guò)GetObject和GetString方法來(lái)實(shí)現(xiàn),以鍵名為參數(shù)就將返回對(duì)應(yīng)的值。
ResourceManager類的構(gòu)造函數(shù)初始化ResourceManager類的新實(shí)例,其重載方法之一查找包含在一些文件中的資源,這些文件是使用給定的 Assembly 從指定根名稱導(dǎo)出的。
復(fù)制代碼 代碼如下:

public ResourceManager(
string baseName,
Assembly assembly
)

其中,參數(shù)baseName表示資源的根名稱。根名稱由應(yīng)用程序名稱空間和資源文件名(不帶擴(kuò)展名)組成。這樣,該例中資源的根名稱應(yīng)該是:UserinfoResource.Userinfo,通過(guò)調(diào)用GetManifestResourceNames()方法也可編程獲取該名稱。
另一個(gè)參數(shù)assembly表示的是當(dāng)前的主程序集,本例中的主程序集其實(shí)也是正在執(zhí)行的程序集。獲取正在執(zhí)行程序集的一個(gè)簡(jiǎn)單方法是調(diào)用Assembly.GetExecutingAssembly()方法。
在獲取ResourceManager實(shí)例后,通過(guò)指定鍵名,就可以獲得對(duì)應(yīng)的資源。
下表是程序中使用的部分控件:
類別 TextBox TextBox TextBox TextBox PictureBox
名稱 username sex birthday salary photo
這些控件均可直接從工具箱拖放到設(shè)計(jì)器中。
完整的源代碼為:
方法一:
復(fù)制代碼 代碼如下:

using System.reflection;
using System.Resources;
private System.Resources.ResourceManager rm;
public Form1()
{
InitializeComponent();
Assembly assembly=Assembly.GetExecutingAssembly();//獲取當(dāng)前主程序集
Rm=new ResourceManager("ResourceUserinfo.Userinfo",assembly);//實(shí)例化資源管理類
photo.iamge=(Image)rm.GetObjetct("Photo");
username.Text=rm.GetString("Username");
sex.Text=rm.GetString("Sex");
birthday.Text=rm.GetString("Birthday");
salary.Text=rm.GetString("Salary");
}

方法二:
復(fù)制代碼 代碼如下:

Assembly assm = this.GetType().Assembly;//Assembly.LoadFrom(程序集路徑);
foreach (string resName in assm.GetManifestResourceNames())
{
Stream stream = assm.GetManifestResourceStream(resName);
ResourceReader rr = new ResourceReader(stream);
IDictionaryEnumerator enumerator = rr.GetEnumerator();
while (enumerator.MoveNext())
{
DictionaryEntry de = (DictionaryEntry)enumerator.Current;
//de.Key是資源名
//de.Value是資源內(nèi)容
}
}

運(yùn)行以上代碼,便可取出資源文件內(nèi)容。
posted @ 2011-12-15 11:40 Tasting 閱讀(21) 評(píng)論(0) 編輯
DoDragDrop 方法的使用
DoDragDrop方法,用于開(kāi)始對(duì)象的拖放操作。
在類庫(kù)中的定義為:
復(fù)制代碼 代碼如下:

[UIPermissionAttribute(SecurityAction.Demand, Clipboard = UIPermissionClipboard.OwnClipboard)]
public DragDropEffects DoDragDrop(
Object data,
DragDropEffects allowedEffects
)

  其中data參數(shù)為要拖放的數(shù)據(jù),如果拖動(dòng)操作需要于另一個(gè)進(jìn)程的應(yīng)用程序相互操作,data代表的數(shù)據(jù)應(yīng)該是基本托管類(String,BitMap,或MetaFile),或者是實(shí)現(xiàn) ISerializable 或IDataObject的對(duì)象。 allowedEffects參數(shù)表示拖放的效果,為一個(gè)枚舉值(DragDropEffects).返回值也為DragDropEffects枚舉值。
  當(dāng)開(kāi)始調(diào)用DoDragDrop方法拖動(dòng)一個(gè)數(shù)據(jù)對(duì)象時(shí),DoDragDrops在拖放過(guò)程中,檢測(cè)當(dāng)前光標(biāo)位置下的控件是不是有效的放置目標(biāo)。如果當(dāng)前光標(biāo)下的控件是有效的放置目標(biāo),則GiveFeedBack事件以指定的拖放效果引發(fā)。在檢測(cè)當(dāng)前位置光標(biāo)是否為有效的拖放目標(biāo)時(shí),DoDragDrops方法同時(shí)跟蹤光標(biāo)位置,鍵盤狀態(tài)和鼠標(biāo)狀態(tài)的更改。
   (1)如果用于移出了一個(gè)窗口,則引發(fā)DragLeave事件。
  (2)如果移入了另外一個(gè)控件,則引發(fā)該控件的DragEnter事件。
  (3)如果鼠標(biāo)移動(dòng),但是停留在一個(gè)控件中,則引發(fā)DragOver事件。
如果檢測(cè)到更改了鍵盤或者鼠標(biāo)狀態(tài),則引發(fā)拖放源的QueryContinueDrag事件, 并根據(jù)事件的QueryContinueDragEventArgs的Action屬性值確定繼續(xù)拖動(dòng),放置數(shù)據(jù)或取消操作。
(1)如果Action屬性指定為Continue,則將引發(fā)DragOver事件。
(2)如果Action屬性指定為Drop,則將放置效果返回給源,以便應(yīng)用程序?qū)?shù)據(jù)進(jìn)行適當(dāng)?shù)牟僮?;例如,如果是移?dòng)操作,則剪切數(shù)據(jù)。
(3)如果是DragAction的值為Cancel,則引發(fā)DragLeave事件
從csdn上摘抄一段示例代碼:
  下面的代碼示例演示在兩個(gè) ListBox 控件之間的拖放操作。當(dāng)拖動(dòng)動(dòng)作啟動(dòng)時(shí),該示例調(diào)用 DoDragDrop 方法。在 MouseDown 事件期間,如果從鼠標(biāo)位置起鼠標(biāo)移動(dòng)的距離大于 SystemInformation..::.DragSize,則啟動(dòng)拖動(dòng)動(dòng)作。IndexFromPoint 方法用于確定在 MouseDown 事件期間要拖動(dòng)的項(xiàng)的索引。
  該示例還演示如何對(duì)拖放操作使用自定義光標(biāo)。該示例要求應(yīng)用程序目錄中存在兩個(gè)光標(biāo)文件:3dwarro.cur 和 3dwno.cur,分別用于自定義拖動(dòng)光標(biāo)和禁止停放光標(biāo)。如果選中 UseCustomCursorsCheckCheckBox,則使用自定義光標(biāo)。自定義光標(biāo)在 GiveFeedback 事件處理程序中設(shè)置。
  鍵盤狀態(tài)在右 ListBox 的 DragOver 事件處理程序中計(jì)算,以確定基于 Shift、Ctrl、Alt 或 Ctrl+Alt 鍵的狀態(tài)將發(fā)生哪種拖動(dòng)操作。放置動(dòng)作在 ListBox 中發(fā)生的位置也在 DragOver 事件期間確定。如果要放置的數(shù)據(jù)不是 String,則 DragDropEffects 中將把 DragEventArgs.sEffect 設(shè)置為 None。最后,停放狀態(tài)在 DropLocationLabelLabel 中顯示。
  要放置的用于右 ListBox 的數(shù)據(jù)在 DragDrop 事件處理程序中確定,并且在 ListBox 中的適當(dāng)位置添加該 String 值。如果拖動(dòng)操作移動(dòng)到窗體邊框的外面,則 QueryContinueDrag 事件處理程序中將取消拖放操作
復(fù)制代碼 代碼如下:

using System;
using System.Drawing;
using System.Windows.Forms;
namespace Snip_DragNDrop
{
public class Form1 : System.Windows.Forms.Form
{
private System.Windows.Forms.ListBox ListDragSource;
private System.Windows.Forms.ListBox ListDragTarget;
private System.Windows.Forms.CheckBox UseCustomCursorsCheck;
private System.Windows.Forms.Label DropLocationLabel;
private int indexOfItemUnderMouseToDrag;
private int indexOfItemUnderMouseToDrop;
private Rectangle dragBoxFromMouseDown;
private Point screenOffset;
private Cursor MyNoDropCursor;
private Cursor MyNormalCursor;
/// The main entry point for the application.
[STAThread]
static void Main()
{
Application.Run(new Form1());
}
public Form1()
{
this.ListDragSource = new System.Windows.Forms.ListBox();
this.ListDragTarget = new System.Windows.Forms.ListBox();
this.UseCustomCursorsCheck = new System.Windows.Forms.CheckBox();
this.DropLocationLabel = new System.Windows.Forms.Label();
this.SuspendLayout();
// ListDragSource
this.ListDragSource.Items.AddRange(new object[] {"one", "two", "three", "four",
"five", "six", "seven", "eight",
"nine", "ten"});
this.ListDragSource.Location = new System.Drawing.Point(10, 17);
this.ListDragSource.Size = new System.Drawing.Size(120, 225);
this.ListDragSource.MouseDown += new System.Windows.Forms.MouseEventHandler(this.ListDragSource_MouseDown);
this.ListDragSource.QueryContinueDrag += new System.Windows.Forms.QueryContinueDragEventHandler(this.ListDragSource_QueryContinueDrag);
this.ListDragSource.MouseUp += new System.Windows.Forms.MouseEventHandler(this.ListDragSource_MouseUp);
this.ListDragSource.MouseMove += new System.Windows.Forms.MouseEventHandler(this.ListDragSource_MouseMove);
this.ListDragSource.GiveFeedback += new System.Windows.Forms.GiveFeedbackEventHandler(this.ListDragSource_GiveFeedback);
// ListDragTarget
this.ListDragTarget.AllowDrop = true;
this.ListDragTarget.Location = new System.Drawing.Point(154, 17);
this.ListDragTarget.Size = new System.Drawing.Size(120, 225);
this.ListDragTarget.DragOver += new System.Windows.Forms.DragEventHandler(this.ListDragTarget_DragOver);
this.ListDragTarget.DragDrop += new System.Windows.Forms.DragEventHandler(this.ListDragTarget_DragDrop);
this.ListDragTarget.DragEnter += new System.Windows.Forms.DragEventHandler(this.ListDragTarget_DragEnter);
this.ListDragTarget.DragLeave += new System.EventHandler(this.ListDragTarget_DragLeave);
// UseCustomCursorsCheck
this.UseCustomCursorsCheck.Location = new System.Drawing.Point(10, 243);
this.UseCustomCursorsCheck.Size = new System.Drawing.Size(137, 24);
this.UseCustomCursorsCheck.Text = "Use Custom Cursors";
// DropLocationLabel
this.DropLocationLabel.Location = new System.Drawing.Point(154, 245);
this.DropLocationLabel.Size = new System.Drawing.Size(137, 24);
this.DropLocationLabel.Text = "None";
// Form1
this.ClientSize = new System.Drawing.Size(292, 270);
this.Controls.AddRange(new System.Windows.Forms.Control[] {this.ListDragSource,
this.ListDragTarget, this.UseCustomCursorsCheck,
this.DropLocationLabel});
this.Text = "drag-and-drop Example";
this.ResumeLayout(false);
}
private void ListDragSource_MouseDown(object sender, System.Windows.Forms.MouseEventArgs e)
{
// Get the index of the item the mouse is below.
indexOfItemUnderMouseToDrag = ListDragSource.IndexFromPoint(e.X, e.Y);
if (indexOfItemUnderMouseToDrag != ListBox.NoMatches) {
// Remember the point where the mouse down occurred. The DragSize indicates
// the size that the mouse can move before a drag event should be started.
Size dragSize = SystemInformation.DragSize;
// Create a rectangle using the DragSize, with the mouse position being
// at the center of the rectangle.
dragBoxFromMouseDown = new Rectangle(new Point(e.X - (dragSize.Width /2),
e.Y - (dragSize.Height /2)), dragSize);
} else
// Reset the rectangle if the mouse is not over an item in the ListBox.
dragBoxFromMouseDown = Rectangle.Empty;
}
private void ListDragSource_MouseUp(object sender, System.Windows.Forms.MouseEventArgs e) {
// Reset the drag rectangle when the mouse button is raised.
dragBoxFromMouseDown = Rectangle.Empty;
}
private void ListDragSource_MouseMove(object sender, System.Windows.Forms.MouseEventArgs e)
{
if ((e.Button MouseButtons.Left) == MouseButtons.Left) {
// If the mouse moves outside the rectangle, start the drag.
if (dragBoxFromMouseDown != Rectangle.Empty
!dragBoxFromMouseDown.Contains(e.X, e.Y)) {
// Create custom cursors for the drag-and-drop operation.
try {
MyNormalCursor = new Cursor("3dwarro.cur");
MyNoDropCursor = new Cursor("3dwno.cur");
} catch {
// An error occurred while attempting to load the cursors, so use
// standard cursors.
UseCustomCursorsCheck.Checked = false;
}finally {
// The screenOffset is used to account for any desktop bands
// that may be at the top or left side of the screen when
// determining when to cancel the drag drop operation.
screenOffset = SystemInformation.WorkingArea.Location;
// Proceed with the drag-and-drop, passing in the list item.
DragDropEffects dropEffect = ListDragSource.DoDragDrop(ListDragSource.Items[indexOfItemUnderMouseToDrag], DragDropEffects.All | DragDropEffects.Link);
// If the drag operation was a move then remove the item.
if (dropEffect == DragDropEffects.Move) {
ListDragSource.Items.RemoveAt(indexOfItemUnderMouseToDrag);
// Selects the previous item in the list as long as the list has an item.
if (indexOfItemUnderMouseToDrag > 0)
ListDragSource.SelectedIndex = indexOfItemUnderMouseToDrag -1;
else if (ListDragSource.Items.Count > 0)
// Selects the first item.
ListDragSource.SelectedIndex =0;
}
// Dispose of the cursors since they are no longer needed.
if (MyNormalCursor != null)
MyNormalCursor.Dispose();
if (MyNoDropCursor != null)
MyNoDropCursor.Dispose();
}
}
}
}
private void ListDragSource_GiveFeedback(object sender, System.Windows.Forms.GiveFeedbackEventArgs e)
{
// Use custom cursors if the check box is checked.
if (UseCustomCursorsCheck.Checked) {
// Sets the custom cursor based upon the effect.
e.UseDefaultCursors = false;
if ((e.Effect DragDropEffects.Move) == DragDropEffects.Move)
Cursor.Current = MyNormalCursor;
else
Cursor.Current = MyNoDropCursor;
}
}
private void ListDragTarget_DragOver(object sender, System.Windows.Forms.DragEventArgs e)
{
// Determine whether string data exists in the drop data. If not, then
// the drop effect reflects that the drop cannot occur.
if (!e.Data.GetDataPresent(typeof(System.String))) {
e.Effect = DragDropEffects.None;
DropLocationLabel.Text = "None - no string data.";
return;
}
// Set the effect based upon the KeyState.
if ((e.KeyState (8+32)) == (8+32)
(e.AllowedEffect DragDropEffects.Link) == DragDropEffects.Link) {
// KeyState 8 + 32 = CTL + ALT
// Link drag-and-drop effect.
e.Effect = DragDropEffects.Link;
} else if ((e.KeyState 32) == 32
(e.AllowedEffect DragDropEffects.Link) == DragDropEffects.Link) {
// ALT KeyState for link.
e.Effect = DragDropEffects.Link;
} else if ((e.KeyState 4) == 4
(e.AllowedEffect DragDropEffects.Move) == DragDropEffects.Move) {
// SHIFT KeyState for move.
e.Effect = DragDropEffects.Move;
} else if ((e.KeyState 8) == 8
(e.AllowedEffect DragDropEffects.Copy) == DragDropEffects.Copy) {
// CTL KeyState for copy.
e.Effect = DragDropEffects.Copy;
} else if ((e.AllowedEffect DragDropEffects.Move) == DragDropEffects.Move) {
// By default, the drop action should be move, if allowed.
e.Effect = DragDropEffects.Move;
} else
e.Effect = DragDropEffects.None;
// Get the index of the item the mouse is below.
// The mouse locations are relative to the screen, so they must be
// converted to client coordinates.
indexOfItemUnderMouseToDrop =
ListDragTarget.IndexFromPoint(ListDragTarget.PointToClient(new Point(e.X, e.Y)));
// Updates the label text.
if (indexOfItemUnderMouseToDrop != ListBox.NoMatches){
DropLocationLabel.Text = "Drops before item #" + (indexOfItemUnderMouseToDrop + 1);
} else
DropLocationLabel.Text = "Drops at the end.";
}
private void ListDragTarget_DragDrop(object sender, System.Windows.Forms.DragEventArgs e)
{
// Ensure that the list item index is contained in the data.
if (e.Data.GetDataPresent(typeof(System.String))) {
Object item = (object)e.Data.GetData(typeof(System.String));
// Perform drag-and-drop, depending upon the effect.
if (e.Effect == DragDropEffects.Copy ||
e.Effect == DragDropEffects.Move) {
// Insert the item.
if (indexOfItemUnderMouseToDrop != ListBox.NoMatches)
ListDragTarget.Items.Insert(indexOfItemUnderMouseToDrop, item);
else
ListDragTarget.Items.Add(item);
}
}
// Reset the label text.
DropLocationLabel.Text = "None";
}
private void ListDragSource_QueryContinueDrag(object sender, System.Windows.Forms.QueryContinueDragEventArgs e) {
// Cancel the drag if the mouse moves off the form.
ListBox lb = sender as ListBox;
if (lb != null) {
Form f = lb.FindForm();
// Cancel the drag if the mouse moves off the form. The screenOffset
// takes into account any desktop bands that may be at the top or left
// side of the screen.
if (((Control.MousePosition.X - screenOffset.X) f.DesktopBounds.Left) ||
((Control.MousePosition.X - screenOffset.X) > f.DesktopBounds.Right) ||
((Control.MousePosition.Y - screenOffset.Y) f.DesktopBounds.Top) ||
((Control.MousePosition.Y - screenOffset.Y) > f.DesktopBounds.Bottom)) {
e.Action = DragAction.Cancel;
}
}
}
private void ListDragTarget_DragEnter(object sender, System.Windows.Forms.DragEventArgs e) {
// Reset the label text.
DropLocationLabel.Text = "None";
}
private void ListDragTarget_DragLeave(object sender, System.EventArgs e) {
// Reset the label text.
DropLocationLabel.Text = "None";
}
}
}

對(duì)用這種拖放操作和微軟的服務(wù),容器模式的關(guān)系,留在以后再學(xué)習(xí)。
posted @ 2011-12-15 11:16 Tasting 閱讀(92) 評(píng)論(0) 編輯
關(guān)于接口的使用
概述: 接口的使用體現(xiàn)了一種泛化的思想。
應(yīng)用場(chǎng)景之一是:
(1)多個(gè)類都要實(shí)現(xiàn)某些動(dòng)作,而該動(dòng)作具體實(shí)現(xiàn)的方式又不一樣。
如對(duì)于創(chuàng)建條件來(lái)的窗體來(lái)說(shuō),要實(shí)現(xiàn)添加整形參數(shù),bool類型參數(shù)和字符串類型參數(shù)的條件添加的窗體。而在具體的實(shí)現(xiàn)整形和字符串的窗體,以及bool類型的添加的窗體過(guò)程中,實(shí)現(xiàn)細(xì)節(jié)又不一樣。
復(fù)制代碼 代碼如下:

public interface IExpressionForm
{
ConditionItemEntity CIEntity { get; set; }
ConditionBranchEntity CIEntity { get; set; }
event Handle OnExpressionHandled; }

  而對(duì)于每個(gè)窗體來(lái)說(shuō),都需要包含CIEntity,CIEntity屬性和OnExpressionHandled添加條件后的事件,因此在IExpressionForm 接口中定義了CIEntity,CIEntity,和OnExpressionHandled。
接著實(shí)現(xiàn)整形參數(shù)的條件添加窗體
復(fù)制代碼 代碼如下:

public partial class frmNumericCondition : Form, IExpressionForm
{
public frmNumericCondition()
{
InitializeComponent();
}
public ConditionItemEntity CIEntity { get; set; }
public ConditionBranchEntity CBEntity { get; set; }
public event Handle OnExpressionHandled;
}

  然后是字符型參數(shù)條件添加窗體
復(fù)制代碼 代碼如下:

public partial class frmVarcharCondition : Form, IExpressionForm
{
public frmVarcharCondition()
{
InitializeComponent();
}
public ConditionItemEntity CIEntity { get; set; }
public ConditionBranchEntity CBEntity { get; set; }
public event Handle OnExpressionHandled;
}

以此類推,實(shí)現(xiàn)其它參數(shù)類型條件添加的窗體。
那我這樣實(shí)現(xiàn)的目的的好處是什么呢?接下來(lái)我們來(lái)看看,我定義的一個(gè)產(chǎn)生窗體的函數(shù)
復(fù)制代碼 代碼如下:

public static IExpressionForm CreateExpressionForm(ConditionType ct)
{
IExpressionForm frm = null;
if (ct == ConditionType.bit)
frm = new frmBitCondition();
else if (ct == ConditionType.datetime)
frm = new frmDateTimeCondition();
else if (ct == ConditionType.numeric)
frm = new frmNumericCondition();
else if (ct == ConditionType.varchar)
frm = new frmVarcharCondition();
return frm;
}

從定義中我們可以看出,返回值類型為IExpressionForm ,是我在上邊定義的接口。因此該函數(shù)可以返回一切實(shí)現(xiàn)了IExpressionForm 接口的類。如frmVarcharCondition 和frmNumericCondition.
這樣就簡(jiǎn)單的實(shí)現(xiàn)了工廠模式,程序可以用很好的擴(kuò)展性。
以上只是接口的應(yīng)用場(chǎng)景之一,也是自己在寫(xiě)代碼的時(shí)候發(fā)現(xiàn)的。寫(xiě)的不好。但也要寫(xiě),一方面是要總結(jié)工作和學(xué)習(xí),在總結(jié)的時(shí)候可以思考和發(fā)現(xiàn),也希望能給閱讀文章的人一些幫助。

您可能感興趣的文章:
  • .NET 資源文件resx、Resources詳細(xì)說(shuō)明
  • 實(shí)例講解.NET中資源文件的創(chuàng)建與使用
  • 在.NET中讀取嵌入和使用資源文件的方法

標(biāo)簽:許昌 信陽(yáng) 西雙版納 常州 萊蕪 朔州 孝感 自貢

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《asp.net中資源文件的使用》,本文關(guān)鍵詞  asp.net,中資,源文件,的,使用,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《asp.net中資源文件的使用》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于asp.net中資源文件的使用的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章