|
Sorry, I forgot the cast. The word "implicitly" should've given you a clue to explicitly cast, though.
-----BEGIN GEEK CODE BLOCK-----
Version: 3.21
GCS/G/MU d- s: a- C++++ UL@ P++(+++) L+(--) E--- W+++ N++ o+ K? w++++ O- M(+) V? PS-- PE Y++ PGP++ t++@ 5 X+++ R+@ tv+ b(-)>b++ DI++++ D+ G e++>+++ h---* r+++ y+++
-----END GEEK CODE BLOCK-----
|
|
|
|
|
hey i found that , thats it , just it!!! :::
HatchStyle style = (HatchStyle)Enum.Parse(typeof(HatchStyle),"Some Value");
There is no SaveGame in real life.
|
|
|
|
|
What is beter convention in C#:
1) To keep each class in seperate .CS file
OR
2) Keep all classes of same namespace in a single .CS file
i know both ways work.. but just wanna know what is a better convention
Muhammad Shoaib Khan
http://geocities.com/lansolution
|
|
|
|
|
One Class - One File (In my opinion)
Having all of one namespace in a single cs file could get very very crowded.
--Colin Mackay--
|
|
|
|
|
In general, what Colin said. Option 1.
Though of course enumeration classes and tightly related classes often stay in one file for me.
regards,
Paul Watson
Bluegrass
South Africa
Brian Welsch wrote:
"blah blah blah, maybe a potato?" while translating my Afrikaans.
Crikey! ain't life grand?
Einstein says...
|
|
|
|
|
Same with me. I also tend to use regions in those cases, too.
-----BEGIN GEEK CODE BLOCK-----
Version: 3.21
GCS/G/MU d- s: a- C++++ UL@ P++(+++) L+(--) E--- W+++ N++ o+ K? w++++ O- M(+) V? PS-- PE Y++ PGP++ t++@ 5 X+++ R+@ tv+ b(-)>b++ DI++++ D+ G e++>+++ h---* r+++ y+++
-----END GEEK CODE BLOCK-----
|
|
|
|
|
>I also tend to use regions in those cases,
Regions are a god send when you have rafts of ugly collection/enumeration code cluttering up a simple enough class.
regards,
Paul Watson
Bluegrass
South Africa
Brian Welsch wrote:
"blah blah blah, maybe a potato?" while translating my Afrikaans.
Crikey! ain't life grand?
Einstein says...
|
|
|
|
|
True. I especially like them for explicit interface implementations! Sure eliminates a lot of code that probably just calls similarly named methods on the class that implements it.
-----BEGIN GEEK CODE BLOCK-----
Version: 3.21
GCS/G/MU d- s: a- C++++ UL@ P++(+++) L+(--) E--- W+++ N++ o+ K? w++++ O- M(+) V? PS-- PE Y++ PGP++ t++@ 5 X+++ R+@ tv+ b(-)>b++ DI++++ D+ G e++>+++ h---* r+++ y+++
-----END GEEK CODE BLOCK-----
|
|
|
|
|
numero uno
so everything is easier to remember
|
|
|
|
|
One class per file, and of course real programmers use nested classes, so even then they tend to get big, hopefully .NET 2 will help out there. It would be nice to group files according to function.
leppie::AllocCPArticle("Zee blog"); Seen on my Campus BBS: Linux is free...coz no-one wants to pay for it.
|
|
|
|
|
One class per file except when the classes are small, very similar or closely related.
I also put all rarely used classes in the same file.
(Like by aggregation).
God bless regions.
|
|
|
|
|
private void Mousedownhere(object sender, System.Windows.Forms.MouseEventArgs e)
{
DataGrid myGrid = (DataGrid) sender;
System.Windows.Forms.DataGrid.HitTestInfo hti;
hti = myGrid.HitTest(e.X, e.Y);
string message = "You clicked ";
switch (hti.Type)
{
case System.Windows.Forms.DataGrid.HitTestType.None :
message += "the background.";
break;
case System.Windows.Forms.DataGrid.HitTestType.Cell :
message += "cell at row " + hti.Row + ", col " + hti.Column;
message += "Row Number : "+Convert.ToString(myGrid.CurrentRowIndex)+"\n\r"+
myGrid[hti.Row, hti.Column];
fscount = hti.Row;
break;
case System.Windows.Forms.DataGrid.HitTestType.ColumnHeader :
message += "the column header for column " + hti.Column;
break;
case System.Windows.Forms.DataGrid.HitTestType.RowHeader :
message += "the row header for row " + hti.Row;
fscount = hti.Row;
string cellvalue = Convert.ToString(myGrid[hti.Row,2]);
// if (cellvalue==”CHINA”)
MessageBox.Show("value is="+cellvalue,Convert.ToString(hti.Row));
break;
//BUT IF I REMOVE THE COMMENTS FROM THE ABOVE if (cellvalue==”CHINA ”) THEN IT DOES NOT SHOW ME //THE MESSAGEBOX
// WHY???????????????
}
}
|
|
|
|
|
Try debugging your code. Put a break-point at the beginning of that case and step through your code, checking the state of variables as you step over each line. And keep in mind that using the == operator for strings results in a case-sensitive comparison. See String.Compare for a better, culture-aware comparison with many more capabilities.
-----BEGIN GEEK CODE BLOCK-----
Version: 3.21
GCS/G/MU d- s: a- C++++ UL@ P++(+++) L+(--) E--- W+++ N++ o+ K? w++++ O- M(+) V? PS-- PE Y++ PGP++ t++@ 5 X+++ R+@ tv+ b(-)>b++ DI++++ D+ G e++>+++ h---* r+++ y+++
-----END GEEK CODE BLOCK-----
|
|
|
|
|
String comparison
Is there any way so that all the below conditions give me true results.
String val = “Hello”
Now comparing val it with the following code.
1 “Hello “ //Note white space at the end of Hello.
2 “ Hello” //Note white space at the beginning of Hello.
3 “Hello “ //Note two white spaces left at the end.
4 “ Hello “ //Note white space both at thebegining and end of Hello.
5 “hello” //Note the caps change.
6 “HEllo” //Note the caps change.
Thanks
|
|
|
|
|
Look at the documentation for the String class - not reading won't teach you anything. Specifically, look at the Compare (like I mentioned before which can do case-insensitive and culture-specific comparisons) and Trim methods.
-----BEGIN GEEK CODE BLOCK-----
Version: 3.21
GCS/G/MU d- s: a- C++++ UL@ P++(+++) L+(--) E--- W+++ N++ o+ K? w++++ O- M(+) V? PS-- PE Y++ PGP++ t++@ 5 X+++ R+@ tv+ b(-)>b++ DI++++ D+ G e++>+++ h---* r+++ y+++
-----END GEEK CODE BLOCK-----
|
|
|
|
|
i'm not a english speaker,i hope you can understand my expression.
i want to compile my code with commands.
i input for example csc example.cs but theres no program result shows.
whether i need any parameter with the "csc" command?
thanks for your help
|
|
|
|
|
C:\WINDOWS\Microsoft.NET\Framework\v1.1.4322>csc /?
Microsoft (R) Visual C# .NET Compiler version 7.10.3052.4
for Microsoft (R) .NET Framework version 1.1.4322
Copyright (C) Microsoft Corporation 2001-2002. All rights reserved.
Visual C# .NET Compiler Options
- OUTPUT FILES -
/out:<file> Output file name (default: base name of file with main
class or first file)
/target:exe Build a console executable (default) (Short form:
/t:exe)
/target:winexe Build a Windows executable (Short form: /t:winexe)
/target:library Build a library (Short form: /t:library)
/target:module Build a module that can be added to another assembly
(Short form: /t:module)
/define:<symbol list=""> Define conditional compilation symbol(s) (Short form:
/d)
/doc:<file> XML Documentation file to generate
- INPUT FILES -
/recurse:<wildcard> Include all files in the current directory and
subdirectories according to the wildcard specifications
/reference:<file list=""> Reference metadata from the specified assembly files
(Short form: /r)
/addmodule:<file list=""> Link the specified modules into this assembly
- RESOURCES -
/win32res:<file> Specifies Win32 resource file (.res)
/win32icon:<file> Use this icon for the output
/resource:<resinfo> Embeds the specified resource (Short form: /res)
/linkresource:<resinfo> Links the specified resource to this assembly (Short
form: /linkres)
- CODE GENERATION -
/debug[+|-] Emit debugging information
/debug:{full|pdbonly} Specify debugging type ('full' is default, and enables
attaching a debugger to a running program)
/optimize[+|-] Enable optimizations (Short form: /o)
/incremental[+|-] Enable incremental compilation (Short form: /incr)
- ERRORS AND WARNINGS -
/warnaserror[+|-] Treat warnings as errors
/warn:<n> Set warning level (0-4) (Short form: /w)
/nowarn:<warning list=""> Disable specific warning messages
- LANGUAGE -
/checked[+|-] Generate overflow checks
/unsafe[+|-] Allow 'unsafe' code
- MISCELLANEOUS -
@<file> Read response file for more options
/help Display this usage message (Short form: /?)
/nologo Suppress compiler copyright message
/noconfig Do not auto include CSC.RSP file
- ADVANCED -
/baseaddress: Base address for the library to be built
/bugreport:<file> Create a 'Bug Report' file
/codepage:<n> Specifies the codepage to use when opening source files
/utf8output Output compiler messages in UTF-8 encoding
/main:<type> Specifies the type that contains the entry point (ignore
all other possible entry points) (Short form: /m)
/fullpaths Compiler generates fully qualified paths
/filealign:<n> Specify the alignment used for output file sections
/nostdlib[+|-] Do not reference standard library (mscorlib.dll)
/lib:<file list=""> Specify additional directories to search in for
references
|
|
|
|
|
Hi friend,
I had same problem with my "Hello World" program using CP. I suggest the following:
1. Don't enter the commands in the MS-DOS mode, instead use the Visual Studio .NET Command prompt.
2. Ensure that your program is saved as as .cs "example.cs"
3. In the VS.NET command prompt type csc example.cs
The program will compile successfully if it has no bug. Then type
example (press enter). Your program begins to run.
Enjoy C#
...the mind is not a vessel to be filled but a fire to ignited
|
|
|
|
|
hi extremeg:
thanks for your help
i find the .exe file was create by csc application at the same folder.so,i create a shortcut of visual studio.net command prompt at desktop then i find that the .exe file was on the desktop too. these days i use this method to compile my code and view results i think your method maybe more convenient! thanks for your help... my english is so poor.. i wish that u could understand my message..
|
|
|
|
|
any equivalent of MAP files in C# for debugging??
Muhammad Shoaib Khan
http://geocities.com/lansolution
|
|
|
|
|
Not exactly like a MAP file - but serves much of the same purpose - the PDB file that is generated in a debug build contains the symbols for a debug version of an executable. While the IL for a debug assembly is pretty much the same as it is for a release assembly (barring a differences, like when you use pre-proc conditions or attribute a method with the ConditionalAttribute ), the debug build contains the path to a PDB file in another file segment. These are useful in debugging and will provide method lookups, line numbers, filenames, etc.
These won't work for release builds, though.
-----BEGIN GEEK CODE BLOCK-----
Version: 3.21
GCS/G/MU d- s: a- C++++ UL@ P++(+++) L+(--) E--- W+++ N++ o+ K? w++++ O- M(+) V? PS-- PE Y++ PGP++ t++@ 5 X+++ R+@ tv+ b(-)>b++ DI++++ D+ G e++>+++ h---* r+++ y+++
-----END GEEK CODE BLOCK-----
|
|
|
|
|
Hi
I need some help in getting a video played in the back ground of my win form where I will add some controls that would display some text and other stuff.
What I did until know is.
Using interop and Com I am able to play the video inside a panel, but here is the problem if I add a control inside the panel ex.
This.controls.add(panel1)
This.panel1.Controls.Add(textcontrol)
When the video loads it is hiding everything in the same control (panel1) but not all the form unless I set the size of panel1 to be as the same size as the form.(I don’t want every thing to be hidden I want the controls to show over the video with an alpha transparency level )
What I did is instead of adding the textcontrol to the panel1 I am adding it to the main form so I am being able to put the text over the video, but I am losing the benefit of having an alpha (transparency) for my text.
I would weolcme any suggestion to solve this and any alternative solution
Simply what I am trying to achieve now is to have a news bar like the one that you can see on CNN by adding text over the video
Thanks for reading this.
Best regards
|
|
|
|
|
Most video players like Windows Media Player (which I assume you're using) show the video in a separate layer that doesn't allow them to be hosted like that, otherwise someone could easily capture the video which may or may not be protected. You can further see proof of this by trying to take a screenshot - you shouldn't see any video.
You should take a look at DirectX: http://msdn.microsoft.com/directx[^]. There's a lot more you have to do, but there are a few examples here on the CP site that should help.
-----BEGIN GEEK CODE BLOCK-----
Version: 3.21
GCS/G/MU d- s: a- C++++ UL@ P++(+++) L+(--) E--- W+++ N++ o+ K? w++++ O- M(+) V? PS-- PE Y++ PGP++ t++@ 5 X+++ R+@ tv+ b(-)>b++ DI++++ D+ G e++>+++ h---* r+++ y+++
-----END GEEK CODE BLOCK-----
|
|
|
|
|
Hallo...
Does anyone know how to read/write/format floppy or hd sectors, tracks, heads, ecc.....
I used to use INT 13h with veeeeery old DOS and old C, but now with WindowsXP and C#???????
Thank you...
|
|
|
|
|
C# - rather, the .NET base class library (BCL) - does not provide such features. This is much too low-level for the BCL. You'll have to P/Invoke native functions (see DllImportAttribute documentation for details). You should also try searching this site or googling the rest of the 'net for any examples.
-----BEGIN GEEK CODE BLOCK-----
Version: 3.21
GCS/G/MU d- s: a- C++++ UL@ P++(+++) L+(--) E--- W+++ N++ o+ K? w++++ O- M(+) V? PS-- PE Y++ PGP++ t++@ 5 X+++ R+@ tv+ b(-)>b++ DI++++ D+ G e++>+++ h---* r+++ y+++
-----END GEEK CODE BLOCK-----
|
|
|
|