用GetWindowLong看看那个控件是否有ES_PASSWORD属性<br><br>Edit Styles<br>ES_AUTOHSCROLL Automatically scrolls text to the right by 10 characters when the user types a character at the end of the line. When the user presses the ENTER key, the control scrolls all text back to position 0.<br><br><br>ES_AUTOVSCROLL Automatically scrolls text up one page when the user presses ENTER on the last line.<br><br><br>ES_CENTER Centers text in a single-line or multiline edit control.<br><br><br>ES_LEFT Left-aligns text in a single-line or multiline edit control.<br><br><br>ES_LOWERCASE Converts all characters to lowercase as they are typed into the edit control.<br><br><br>ES_MULTILINE Designates a multiple-line edit control. (The default is single line.) If the ES_AUTOVSCROLL style is specified, the edit control shows as many lines as possible and scrolls vertically when the user presses the ENTER key. If ES_AUTOVSCROLL is not given, the edit control shows as many lines as possible and beeps if ENTER is pressed when no more lines can be displayed. If the ES_AUTOHSCROLL style is specified, the multiple-line edit control automatically scrolls horizontally when the caret goes past the right edge of the control. To start a new line, the user must press ENTER. If ES_AUTOHSCROLL is not given, the control automatically wraps words to the beginning of the next line when necessary; a new line is also started if ENTER is pressed. The position of the wordwrap is determined by the window size. If the window size changes, the wordwrap position changes and the text is redisplayed. Multiple-line edit controls can have scroll bars. An edit control with scroll bars processes its own scroll-bar messages. Edit controls without scroll bars scroll as described above and process any scroll messages sent by the parent window.<br><br><br>ES_NOHIDESEL Normally, an edit control hides the selection when the control loses the input focus and inverts the selection when the control receives the input focus. Specifying ES_NOHIDESEL deletes this default action.<br><br><br>ES_OEMCONVERT Text entered in the edit control is converted from the ANSI character set to the OEM character set and then back to ANSI. This ensures proper character conversion when the application calls the AnsiToOem Windows function to convert an ANSI string in the edit control to OEM characters. This style is most useful for edit controls that contain filenames.<br><br><br>ES_PASSWORD Displays all characters as an asterisk (*) as they are typed into the edit control. An application can use the SetPasswordChar member function to change the character that is displayed.<br><br><br>ES_RIGHT Right-aligns text in a single-line or multiline edit control.<br><br><br>ES_UPPERCASE Converts all characters to uppercase as they are typed into the edit control.<br><br><br>ES_READONLY Prevents the user from entering or editing text in the edit control. <br><br><br>ES_WANTRETURN Specifies that a carriage return be inserted when the user presses the ENTER key while entering text into a multiple-line edit control in a dialog box. Without this style, pressing the ENTER key has the same effect as pressing the dialog box’s default pushbutton. This style has no effect on a single-line edit control. <br><br><br>另外转一个代码,记得给我分哦<br><br>function lpEnumFunc(hwnd:integer;uint:integer):boolean;stdcall;<br>var hw,hs,wlong:integer;<br> sbuf,sb2:array[0..256] of char;<br> sb1:string;<br>begin<br> [blue]wlong:=GetWindowLong(hwnd,GWL_STYLE);<br> if (wlong and ES_PASSWORD)<>0 then[/blue] begin<br> inc(hcount);<br> hw:=GetWindowTextLength(hwnd);<br> sendmessage(hwnd,wm_gettext,40,integer(@sbuf));<br> strpcopy(sbuf,format('[Password %d] = %s',[hcount,sbuf]));<br> form1.listbox1.items.add(strpas(sbuf));<br> end;<br> result:=true;<br>end;