Trucos VFP.pdf

May 23, 2018 | Author: Carlos Javier Gutierrez Oduber | Category: Microsoft Sql Server, Point And Click, Window (Computing), Microsoft Word, Double Click


Comments



Description

Trucos - Visual FoxProLOS TRUCOS AQUI MOSTRADOS HAN SIDO RECOPILADOS DE VARIAS PAGINAS Y NO SON PROPIEDAD INTELECTUAL DEL AUTOR DE ESTE BLOG, HAN SIDO RECOPILADOS CON EL FIN DE QUE SIRVAN COMO AYUDA A MUCHOS PROGRAMADORES. Mostrar un reporte dentro de un formulario Excelente truco con el cual podrás mostrar tu reporte en un formulario. oRep =Createobject("Form") With oRep .Caption= "Titulo del Reporte" .WindowState= 2 .Show() Endwith Report Form MiReporte.frx Preview Window (oRep.Name) Hacer que hable el PC Excelente truco que utiliza el objeto COM SAPI que viene con WinXP el cual "pronuncia" lo que le escribas. oVoz = CreateObject("SAPI.SpVoice") oVoz.Speak("Visual fox Pro") oVoz.Speak("Lo mejor") Extraer información de los MP3 Quieres conocer la información de los archivos MP3 ?? ... autor, titulo, álbum, año ... lnFile = Fopen(Getfile()) Fseek(lnFile, -128,2) lcTag = Fread(lnFile, 128) ? "Titulo: ", Strtran(Substr(lcTag,4,30), Chr(0)) ? "Artista: ", Strtran(Substr(lcTag,34,30), Chr(0)) ? "Album: ", Strtran(Substr(lcTag,64,30), Chr(0)) ? "Año: ", Val(Substr(lcTag,94,4)) Fclose(lnFile) Suprimir ventana "Imprimiendo" en VFP 8 Uno de las nuevas características incorporadas en VFP 8, si deseas puedes impedir que se vea la ventana "Imprimiendo" que se muestra cuando ejecutas un reporte. Report Form NombreReporte To Printer Prompt NODIALOG Preview Nombre del dominio en que se logeo el PC p align="justify">Un pequeño truco para cuando quieras determinar en que dominio se logeo un determinado PC. ? GetEnv("USERDOMAIN") Determinar si una unidad de red esta disponible Esta es la forma más sencilla para determinar si un equipo de la red esta encendido o si esta disponible una determinada unidad de red. Si la unidad esta disponible se devolverá -1 y si la unidad no existe o esta apagado el PC entonces devolverá -1 ? DISKSPACE("\\NombreServidor\C\") Compactar base de datos de Access desde VFP Muy buen truco que permite compactar una base de datos de Access desde VFP. oJE = CreateObject("JRO.JetEngine") oJE.CompactDatabase("Data Source=" + "d:articulos.mdb", "Data Source=" + "d:articulos1.mdb") Los parámetros para el método CompacDatabase son los siguientes Primer parámetro "Data Source=" + "ruta de la base de datos a compactar" Segundo parámetro "Data Source=" + "ruta de la nueva base de datos compactada" Insertando registros en Access desde VFP Este es un ejemplo básico pero bueno de como interactuar con una base de datos de Access desde VFP. cStrConn = "DRIVER={Microsoft Access Driver (*.mdb)};" +; "Dbq=C:somedata.mdb;" +; "Uid=usuario;" +; "Pwd=password;" lnAccess = SQLSTRINGCONNECT(cStrConn) If lnAccess > 0 SQLEXEC(lnAccess, "INSERT INTO NombreTabla (campo1, campo2) VALUES(00001, 485745)") Else =MessageBox("No fue posible conectarse a la Base de Datos") EndIf Imprimir el contenido de un RTF El RTF es un control ActiveX que permite dar características al texto al estilo de Word. En el ejemplo se muestra como imprimir el contenido de este ActiveX. Para imprimir el contenido debes utilizar el método SelPrint del control RTF ... With Thisform.Rtf .selstart=1 .sellength=len(.textrtf) .selprint Desplegar el Contenido de un Combo En ocasiones queremos conocer el contenido de un ComboBoX sin hacer click en él, solamente a lo que él recibe el enfoque. Esta es la forma más fácil de hacerlo. KEYBOARD _{F4}_ En este caso agregamos este código al evento GOTFOCUS( ) y cuando el Combo reciba el enfoque entonces este se desplegara mostrando la información contenidas en él. Desplegar un ComboBox al recibir el Enfoque II En realidad muchas veces deseamos hacer esto, pero lo pensamos bastante y no encontramos la forma de hacerlo. Por fin aquí esta su implementación. Crea un formulario y agrégale un Combo y un Botón. Al hacer click en el botón debe desplegarse automáticamente el Combo. Programa lo siguiente en el evento Gotfocus del Combo tColumna = THISFORM.Combo1.Left + THISFORM.Combo1.Width - 4 tFila = THISFORM.Combo1.Top + 2 MOUSE CLICK AT tFila, tColumna PIXELS WINDOW (THISFORM.Name) En el evento Click del botón que creaste llama al evento Setfocus() del combo, Así: Thisform.combo1.Setfocus() Quitar acentos de una cadenas de caracteres Algunas veces los acentos son algo molestos y nos causan inconvenientes, sobre todo al momento de realizar búsquedas dentro tablas lCadena = "El amor es el perdón más fácil" ? CHRTRAN(lCadena, "áéíóúáéíóú", "aeiouAEIOU") Agregar imagen al _Screen En ocasiones queremos que en el fondo de nuestras aplicaciones, es decir en el _screen se vea el logo de nuestro programa o de la empresa. Este es un buen truco para personalizar las aplicaciones. _screen.addobject("oImg", "image") _screen.oImg.picture = "c:imagen.jpg" _screen.oImg.visible = .T. _screen.oImg.stretch = 1 _screen.oImg.width = 800 _screen.oImg.height = 600 Quitar botones de la barra del Preview Truco indispensable si deseas quitar algunos botones de la barra del preview e impedir así que se imprima desde ahí o se seleccione alguna opción. Bueno para realizar este truco te recomiendo cierres todo. Ahora ve al menú VER, luego a ToolBars (Barra de herramientas), luego selecciona la barra Print Preview (VISTA PRELIMINAR) y ahora haz click en Customize (PERSONALIZAR). Ahora la barra te aparecerá deshabilitada detrás de ventana de personalización, ve a la barra y con click sostenido quita todos los botones que quieras y listo la configuración se guardara en Foxuser.dbf Si deseas que el usuario final no pueda acceder Solucionar problemas de Memoria con WinXP Evitar el error de Memoria en XP al ejecutar comandos de D.O.S Edita el archivo SYSTEM.INI, en la sección 386ENH agrega la siguiente linea: PerVMFiles = 80 Invocar cuadros de dialogo de Windows Existe una forma sencilla de invocar cuadros de dialogo de Windows, tales como: Guardar, Abrir, Fuentes, Color, Impresoras, Ayuda. loComDialog = newobject( "mscomdlg.commondialog" ) locomdialog.ShowFont && Mostrar Fuente locomdialog.ShowPrinter() && Mostrar Impresora locomdialog.ShowColor() && Mostrar Colores locomdialog.ShowSave() && Mostrar Guardar loComDialog.ShowOpen && Mostrar Abrir Unidad y serial lógico de las unidades de disco De una unidad de disco es posible obtener 2 seriales: el de fabrica y el que le asigna el sistema operativo; en este ejemplo se devuelve el serial del sistema operativo. objWMI = Getobject("winmgmts:\\") cCadWMI = "Select * from Win32_LogicalDisk" oSistema = objWMI.ExecQuery(cCadWMI) For Each Disco In oSistema ? "Unidad: " + Disco.Name + " Serial: " + Disco.VolumeSerialNumber Next Cancelar todos los trabajos en impresión Aquí tienes un ejemplo de como cancelar los trabajos que se esten imprimiendo utilizando WMI. objWMI = GetObject("winmgmts:\\") cCadWMI = "Select * from Win32_Printer Where Name = 'Canon S200'" objImp = objWMI.ExecQuery(cCadWMI) For Each objPrinter in objImp objPrinter.CancelAllJobs() Next Información del tiempo local Utilizando WMI para conocer el día, mes, año, día del mes, número de semana en el mes, minutos, segundos.... etc. objWMI = GetObject("winmgmts:\\") cCadWMI = "Select * from Win32_LocalTime" oTime = objWMI.ExecQuery(cCadWMI) For Each oLocal in oTime ? "Día: " + Transform(oLocal.Day) ? "Día de la semana: " + Transform(oLocal.DayOfWeek) ? "Hora: " + Transform(oLocal.Hour) ? "Minutos: " + Transform(oLocal.Minute) ? "Mes: " + Transform(oLocal.Month) ? "Segunds: " + Transform(oLocal.Second) ? "Semana en el mes: " + Transform(oLocal.WeekInMonth) ? "Año: " + Transform(oLocal.Year) Next Mandar un reporte a una impresora especifica * Beginning of program for Example 1 * ******************************************************* * This program assumes a report called Test which has been * saved with the default printer in the Print Setup dialog. * LOCAL lcPrinter lcPrinter = '' lcPrinter = GETPRINTER() IF !EMPTY(lcPrinter) SET PRINTER TO NAME (lcPrinter) REPORT FORM Test TO PRINTER NOCONSOLE ELSE WAIT WINDOW 'Print Job Cancelled' TIME 1 ENDIF * IMPRIMIR EN UN PUERTO USB Printing to USB Printers from FoxPro 2.6 There are several solutions, depending on your configuration. 1. If you are using a shared printer on another computer, you shouldn't have a problem. Share it from the other computer, and point to it from the FoxPro 2.6 computer. 2. To print to a USB printer on the FoxPro 2.6 computer. On Windows XP and 2000, you can share the printer, then use a NET USE command to redirect LPT1 to the shared printer. This is like the Novell capture sequences. Install the printer and share it. You may need to set permissions to allow Authenticated Users to use the printer. Add NET USE LPT1: \\CRAIG\USBPRINTER to the logon script for the user's profile. For help on logon scripts, look up "To assign a logon script to a profile" in XP Help. 3. To print to a USB printer on the FoxPro 2.6 computer. On Windows XP, you can use printer pooling. Install the USB printer on the computer. Install a local printer on LPT1 (works best, or LPT2). Don't have XP search, but pick the printer by brand. Let it be similar or common printer you recognize. Now select printer properties for the new LPT1 (virtual) printer. On the ports tab, put checks for the LPT1 (for the virtual printer) and the USB for the real printer. Now choose Enable printer pooling. The DOS drivers will print to LPT1. Since XP pools the ports, the output will then be directed to the USB printer. Good luck! If this was helpful, send me ( [email protected] ) an email. Joost Dekker of the Netherlands says "It works." Comprimir con WinZIP Puedes utilizar WinZIP para comprimir archivos desde VFP. oZip = CreateObject("WScript.Shell") oZip.Run("Winzip -a -r -p -ex c:\archivo.zip c:\Dir_a_Comprimir\*.*", 0,.T.) Release oZip oZip = Null Leer archivo INI Una alternativa muy frecuente para almacenar algunos datos de tu aplicación son los archivo INIs ... aquí tienes la forma de leer las entradas de estos archivos. Para el ejemplo crea un archivo INI llamado "archivo.ini" en c: y agrégale los siguientes datos: [RUTADB] Directorio =C:MiProgramaDB Ahora si desde VFP quisiéramos conocer el valor almacenado en la entrada Directorio deberíamos hacerlo así: ? LeerIni("RutaDB","Directorio","c:archivo.ini") Function LeerIni(cSection, cEntry, cINIFile) LOCAL cDefault, cRetVal, nRetLen cDefault = "" cRetVal = Space(255) nRetLen = LEN(cRetVal) DECLARE integer GetPrivateProfileString IN WIN32API ; STRING cSection, String cEntry, ; STRING cDefault, STRING @cRetVal, ; INTEGER nRetLen, STRING cINIFile nRet = GetPrivateProfileString(cSection, cEntry, cDefault, ; @cRetVal, nRetLen, cINIFile) Return Left(cRetVal, nRetLen) EndFunc Desplazamiento con "ENTER" en grid . 2) Abrir un documento de Word e impedir que lo editen En este ejemplo se abre un documento de Word a través de automatización y se impide que el usuario pueda realizar cambios sobre él. Lo que debes hacer es ir al evento KeyPress del TextBox vinculado a la columna y escribir el siguiente código If nKeyCode = 13 Nodefault Keyboard "{DNARROW}" EndIf Devolver número con 2 decimales sin aproximarlo En muchas ocasiones tenemos un número con más de 2 decimales y queremos que solo nos devuelva 2. pero podemos hacer que se desplace al siguiente registro. Local loWord As Object loWord = Createobject("word.Protect(1) loWord.Documents.Caption= "Titulo del Reporte" . no funcionaran las combinaciones de teclas para copiar (CTRL+C)..F.T.Open(Getfile().6935 nNum2 = 1235.Visible= . pero al hacerlo el número es aproximado.Close(.application") loWord.) loWord. 2) ? Round(Floor(nNum2 * 100) / 100.ActiveDocument. Pegar (CTRL+V). loWord.. ON KEY LABEL CTRL+V * ON KEY LABEL CTRL+C * Cuando el usuario presione dichas combinaciones de teclas no harán nada. El asterisco ( * ) permite inhabilitar algunas cositas de VFP..ActiveDocument. mejor dicho ¿quieres esconder tus errores? .Name) Deshabilitar algunas combinaciones de teclas Interesante truco con el cual podrás deshabilitar algunas combinaciones de teclas y hasta funciones de VFP. lo cual queremos evitar..WindowState= 2 .ActiveDocument.. Quieres que tu programa nunca mande un error.Quit Release loWord Mostrar un reporte dentro de un formulario Excelente truco con el cual podrás mostrar tu reporte en un formulario.PrintPreview loWord. oRep =Createobject("Form") With oRep . Gracias a Gorka.05685 ? Round(Floor(nNum1 * 100) / 100.1) loWord...Por defecto cuando presionamos "Enter" en un grid este se desplaza a la siguiente columna. y de igual forma puedes hacer con todas las teclas.frx Preview Window (oRep. Interesante no? . nNum1 = 9874.Show() Endwith Report Form MiReporte. en este caso. 10 mouse dblclick at 11.... cada F3 que envíes hará que el zoom del preview sea más pequeño Comprimir y descomprimir con WinXP Puede incorporar dentro de sus aplicaciones rutinas para comprimir y descomprimir archivos a través de WinXP o WinME.Items oShell..Application") For Each oArchi In oShell.DLL Move Window _Print Preview_ to 10.NameSpace(cNuevoZip)..18). Agrega el siguiente código en el método BeforeOPenTable del dataenvironment (entorno de datos) del reporte ZOOM WINDOW "Report Designer" MAX KEYBOARD "{F3}" &&75% *KEYBOARD "{F3}{F3}" &&50% *KEYBOARD "{F3}{F3}{F3}" &&25% *KEYBOARD "{F3}{F3}{F3}{F3}" &&10% Lo que debes hacer es enviarle pulsaciones de la tabla F3 con la función Keyboard.NameSpace(cOrigen).frx preview nowait If wexist("Print Preview") move window _Print Preview_ to 10.CopyHere(oArchi) .11 Endif Anclar la Barra del Preview de Reportes Cuando ejecutamos un reporte y este muestra la barra de Preview.Zip" cOrigen = "c:Directorio" Strtofile(Chr(0x50)+Chr(0x4B)+Chr(0x05)+Chr(0x06)+Replicate(Chr(0).On Error * Y si deseas evitar que el usuario salga del programa .10 Mouse Dblclick at 11. On Shutdown * Prueba con otras opciones y comprobaras lo útil que es el asterisco ( * ) Anclar barra del preview de los reportes Si deseas que cuando hacer un report form la barra del preview se ancle puedes utilizar este código. ************************************ * COMPRIMIR ************************************ cNuevoZip = "C:MiArchivo. a unos les gusta el preview al 100% a otros les gusta verlo al 50% .11 Endif Preview de los reportes a un zoom especifico Nuestro clientes piden muchas cosas (por no decir otra cosa). muchas veces deseamos colocarla anclada al resto de barras. aquí esta la forma de hacerlo. Coloca el siguiente código en el Init del Dataenvironment If wexist("Print Preview") && O WEXIST(_Vista Preliminar_) si utilizas VFPXESN. Primero ejecutamos el reporte con la cláusula tradicional: Report Form nombrereporte.cNuevoZip) oShell = Createobject("Shell. Declare Long FindWindow In "user32" .Zip" cDirDesti = "c:Directorio" oShell = Createobject("Shell. 1. .Long wMsg.Items oShell.. pero al hacerlo el número es aproximado. lo que hacemos entonces es cerrarlo. 0x0. la primera: nAño = 2004 ? !Empty(Date(nAño."").Application") For Each oArchi In oShell. je.NameSpace(cMiZip).Date(Year(Date()). lo cual queremos evitar. ?DiaDelAño(Date()) ?DiaDelAño(Date()-10) ?DiaDelAño(Date()-60) Function DiaDelAño(dDate) nDia = dDate . Existen diversas formas de terminarlo . 0.6935 nNum2 = 1235.. WM_CLOSE. String lpWindowName Declare Long SendMessage In "user32" . 2) Cerrar el Botón inicio de Windows En ocasiones no queremos que el usuario tenga acceso al botón inicio de Windows. 0) Calcular el número del día en el año Función que te devuelve cuantos días han pasando en el año hasta una fecha determinada.CopyHere(oArchi) EndFor Devolver número con 2 decimales sin aproximarlo En muchas ocasiones tenemos un número con más de 2 decimales y queremos que solo nos devuelva 2. je. Long hWnd1. String lpClassName. nNum1 = 9874.. 1) + 1 Return(nDia) Endfunc Determinar si un año es bisiesto No hace falta explicar.. Long wParam. "Button". 02.. String lpsz1. String lpsz2 #Define WM_CLOSE 0x10 SendMessage(FindWindowEx(FindWindow("Shell_TrayWnd".). 2) ? Round(Floor(nNum2 * 100) / 100. 29)) . je.05685 ? Round(Floor(nNum1 * 100) / 100.. Long hWnd2..Endfor ************************************ * DESCOMPRIMIR ************************************ cMiZip = "C:MiArchivo.Null.NameSpace(cDirDesti). Long Lparam Declare Long FindWindowEx In "user32" . Long HWnd. 29)) Otra forma utilizando MOD ?Mod(2004.F. DELETEMARK = . 4) ?Mod(2005. Caption = "Trabajando con DyamicBackGround" Width = 600 Height = 400 MinHeight = 300 MinWidth = 300 Add Object grid1 As Grid With . DataSession = 2 AutoCenter = .T.GetBackColor(allt(country))") EndProc Procedure Resize This.grid1. 4) Grid y DynamicBackColor Un excelente ejemplo de como podemos utilizar DynamicBackColor para establecer un color a la celda dependiendo de una condición. WIDTH = This.nAño = 2005 ? !Empty(Date(nAño. "Thisform. HEIGHT = This.255. Into Cursor TmpCust Use In "customer" EndProc Procedure Init This. Procedure Load Select * From (_samples+"datacustomer") .grid1. 02.Width This.Height= This.255) Case cCountry == "UK" .Width= This.Height EndProc Function GetBackColor(cCountry) Local nColor Do Case Case cCountry == "Germany" nColor = Rgb(255.Show(1) Define Class myform As Form DoCreate = .T. .grid1.SetAll("dynamicbackcolor".Width..Height. Localo o = Createobject("myform") o. Order By MaxOrdAmt Desc. . Podrás ejecutar tus comando de MS-DOS sin que se muestre la ventana negra del DOS. nSeg = 276786 ? Padl(Int( nSeg / 86400).160) Case cCountry == "Spain" nColor = Rgb(100.224. String cAction.100...224. String cParams.cArchivo.224..."Open". horas.224. En la variable cComando puedes colocar cualquier instrucción válida de MS-DOS que luego será ejecutada.*" cArchivo = GetEnv("TEMP") + "" + Sys(2015) + ".FontSize)+1)) nLines = Memlines(.Edit1 Set Memowidth To Floor(.... + Padl(Int((nSeg % 86400)/3600)..FontName..nColor = Rgb(224. String cFile. Integer nShow cComando = "Dir c:*..0) Case cCountry == "Sweden" nColor = Rgb(224.Value) EndWith ? "Número de líneas.224) EndCase Return nColor EndFunc EndDefine Ejecutar comandos de MS-DOS sin que se muestre la ventana Excelente .segundos Código bastante útil . Si deseas que la ventana sea visible solo cambia el último parámetro de a función ShellExecute y colócalo en 1 Declare Integer ShellExecute In shell32. podemos convertir un número determinado de segundos en días."0") + " Hrs ".160) Case cCountry == "France" nColor = Rgb(100.."".bat" =StrToFile(cComando. Con este truco podrás determinar le número de líneas que ocupa una determinada cadena de texto en un EditBox.2. cArchivo) =ShellExecute(0.Width/(Fontmetric(6. Integer hndWin.Dll.0) Determinar el número de líneas de un EditBox MUY BUENO ."".3) + " Días "..minutos .. minutos..horas . " + Transform(nLines) Set Memowidth To nActSetMemo Convertir segundos a días . nActSetMemo = Set("MemoWidth") With Thisform. String cDir. .160) Otherwise nColor = Rgb(224. T. This. 2.(Len(lcMess)/2))Nowait Dejar fija primera columna de un grid Este es un truco bastante solicitado . LockScreen= . tDateTime2) Local cRet..."0") + " Seg" Wait window centrado en la pantalla Truquito sencillo pero bueno. ?HMSDif(Datetime(). Dtot(Date()-10)) Function HMSDif (tDateTime1.tDateTime1 Else nS = tDateTime1 . ** Y en el Scrolled del Grid esto : Lparameters nDirection Thisform. lcMess = "Mesaje centrado en la pantalla" Wait lcMess Window At Srows()/2. Calcular el número de horas.LockScreen= .Horas ..LockScreen = .RelativeColumn If nPos>0 This.T. LeftColumn Thisform.2. If nDirection > 3 This . nS cRet = "" If! Vartype(tDateTime1)= "T" Or !Vartype(tDateTime2)= "T" cRet = "E" Endif If Empty(cRet) If tDateTime2 > tDateTime1 nS = tDateTime2 .Minutos .LeftColumn Endif Thisform. Aquí tienes 2 formas de hacerlo.ColumnOrder=1 Endif Diferencia entre dos DateTime .F. LockScreen = . + Padl(Int(nSeg % 60). minutos y segundos entre dos valor DateTime.+ Padl(Int((nSeg % 3600)/60).Columns(1).COlumn1. ColumnOrder = This. Con VFP 8 o superior ya es posible hacerlo más fácilmente.ColumnOrder=nPos+1 Else This.(Scols()/2 .tDateTime2 Endif .T. "0") + " Min ". En el AfteRowColchange del Grid digita lo siguiente: Lparameters nColIndex Thisform.ColumnOrder =This. ActiveColumn-This. OTRA FORMA ** En el AfteRowColchange del Grid digita lo siguiente: nPos =This...Columns(1).COlumn1.Segundos Este truco es bastante útil . 60).nS = Int(nS) cTime = Transform(Int(nS/3600). para ello deberás crear un icono que te ."99")+":"+ .53) % 1 ? ABS(329. En el evento GotFocus() del control colocas lo siguiente: Keyboard '{END}' Keyboard '{SHIFT+HOME}' Apagar rápidamente con WinXP Puedes hacer que tu PC se apague con doble clic.. está es una forma sencilla pero bastante buena. cOsx = Os(1) cSistema = "" Do Case Case "6.60).0" $ cOsx Or "3." 99") Return cTime Else =Messagebox("Los valores deben ser DateTime") Return "" Endif Endfunc Sistema operativo que utilizas Existen diversas formas de conocer que sistema operativo utilizas." $ cOsx cSistema = "3.9" $ cOsx cSistema = "95" Case "3. de como determinar la parte decimal o fraccionaria de un número. Transform(Mod(Int(nS/60)..00" $ cOsx cSistema = "LongHorn" Case "5.1" $ cOsx cSistema = "98" Case"4.02" $ cOsx cSistema = "2003" Case "5.9" $ cOsx cSistema = "ME" Case "4."9999")+":"+ . Transform(Mod(nS.. ? ABS(78..1" Endcase ? "Windows " + cSistema Obtener la parte fraccionaria de un numero Un truco EXCELENTEEEE .12) % 1 Seleccionar el texto de un control Una forma sencilla de seleccionar el texto de un control .01" $ cOsx cSistema = "XP" Case "5..0" $ cOsx cSistema = "2000" Case "NT" $ cOsx cSistema = "NT" Case "4. para realizar este truco sigue estos pasos: Haz clic con el ratón derecho en una zona libre del Escritorio y luego selecciona Nuevo y Acceso directo.t. ? SET("PRINTER".15 . Calcular tiempo que tarda realizar una Operación Un simple pero muy interesante ejemplo de como y donde implementar estas útiles funciones. En la ventana del acceso directo debes escribir shutdown -s -t 00 y pulsa el botón Siguiente.lnInicio Texto parpadeante Para realizar el efecto debemos crear un formulario. Después de él indicamos la pagina de inicio y final del reporte a imprimir.Visible Impedir que cambien la configuración del Preview de Reportes Si no quieres que te modifiquen la configuración del Preview de reportes desde abrir la tabla de recursos de VFP (Foxuser. después le pones el nombre que quieras al acceso directo y pinchas el botón Finalizar. Si quieres dejar algo de tiempo para cerrar las aplicaciones debes poner esto shutdown.dbf) y cambiar a verdadero (.) el campo solo lectura (ReadOnly) de la barra.permita hacer esta función. lnInicio = SECONDS() for i = 1 to 10000 && en este ejemplo cuanto tarda realizar && el ciclo for de 1 hasta 10000 endfor ? SECONDS() . 3) && Impresora predeterminada de VFP Imprimir paginas determinadas de un Reporte Cuando tenemos un reporte y queremos imprimir una pagina determinada o desde una pagina a otra podemos utilizar el argumento RANGE.Label1. 2) && Impresora predeterminada de Windows ? SET("PRINTER". Cambiamos la propiedad caption de la etiqueta a al texto que deseamos. Use SYS(2005) Again Locate For Id=_TTOOLBAR_ and name=_Print Preview_ Replace readonly with . la propiedad Interval de este se la establecemos a 700 (milisegundos).Label1.Visible =! THISFORM. Use Determinar la Impresora predeterminada En VFP la impresión causa algunos malestares y debemos conocer cual es la impresora predeterminada tanto en Windows como en VFP. luego ejecutamos.T. una etiqueta y un control timer. En el evento Timer del Control Timer escribimos: THISFORM. yo puedo mandar a imprimir de la pagina 10 a la 15 de la siguiente manera REPORT FORM nombreinforme RANGE 10. Supongamos que tenemos un reporte de 20 paginas.exe -s t 12 de esta forma dejarás un margen prudencial de 12 segundos para apagar el PC. Printout(.OpenReport("C: eporteventas.doc" oRepx. No quiero decir con esto que sea mejor.FormatType = 14 && Formato de Word oRepx.crpe.doc" oRepx.ExportOptions. Primero veamos como puedo exportar un reporte a extensión .crpe.F.F.RPT") oRepx. no muestra cuadro para configurar impresora Crystal Report y VFP Uno de los grandes problemas de VFP son los reportes.application") oRep = oCristalreport. Primero veamos como puedo exportar un reporte a extensión .DOC (Word) oCristalReport = createobject("crystal. simplemente es otra forma de hacerlo y tiene muchas ventajas. más fácil o más cómodo.crpe.) && No muestra ningun cuadro de Dialogo release oRepx release oCristalReport Los otros formatos en que podemos guardar los reportes son: Extensión FormatType RTF 4 EXCEL 7 27 o 28 .OpenReport("C: eporteventas. más fácil o más cómodo.ExportOptions.) && No muestra ningun cuadro de Dialogo release oRepx release oCristalReport Los otros formatos en que podemos guardar los reportes son: Extensión FormatType RTF 4 EXCEL 7 27 o 28 EXCEL 8 29 o 30 Para ver en vista previa un reporte: oCristalreport = createobject("crystal.DestinationType = 1 && Tipo de Destino a guardar oRepx.ExportOptions.F.Preview Para mandarlo a imprimir oCristalreport = createobject("crystal.OpenReport("C: eporteventas. No quiero decir con esto que sea mejor.OpenReport("C: eporteventas.RPT") oRep. simplemente es otra forma de hacerlo y tiene muchas ventajas.DOC (Word) oCristalReport = createobject("crystal.Export(.ExportOptions.) && .ExportOptions.application") oRepx = oCristalReport.FormatType = 14 && Formato de Word oRepx. pero podemos realizar los reportes en Cristal Report y luego llamarlos desde VFP. pero podemos realizar los reportes en Cristal Report y luego llamarlos desde VFP.Export(.crpe.RPT") oRepx. En los ejemplos que demuestro estoy utilizando la versión 8 del Cristal Report de Seagate pero considero que se debe comportar igual con las demás versiones.application") oRep = oCristalreport.Crystal Report y VFP Uno de los grandes problemas de VFP son los reportes.DiskFileName = "c: eporteventasdelmes.application") oRepx = oCristalReport.ExportOptions.DestinationType = 1 && Tipo de Destino a guardar oRepx. En los ejemplos que demuestro estoy utilizando la versión 8 del Cristal Report de Seagate pero considero que se debe comportar igual con las demás versiones.DiskFileName = "c: eporteventasdelmes.RPT") oRep.F. OpenReport("C: eporteventas.F.Scalemode = 0 Wait Window cMensage At Int(_Screen.crpe.application") oRep = oCristalreport. en la sección 386ENH agrega la siguiente linea: PerVMFiles = 80 Impedir que cambien el tamaño de las Columnas de un Grid Si quiere que nadie cambie el tamaño de las columnas de un grid.Width/2 .RPT") oRep. con este truco se muestra centrado en la pantalla.Height/2).OpenReport("C: eporteventas. Solucionar problemas de Memoria con WinXP Evitar el error de Memoria en XP al ejecutar comandos de D.F.) && .F. "Column") . ve a la barra y con click sostenido quita todos los botones que quieras y listo la configuración se guardara en Foxuser.EXCEL 8 29 o 30 Para ver en vista previa un reporte: oCristalreport = createobject("crystal. puede utilizar esta forma. Bueno para cambiar las propiedades de los reportes desde código debemos abrir el reporte como una tabla: USE nombrereporte. si en fontstyle ponemos 0 tendremos letra normal.dbf con tu proyecto. .O. no muestra cuadro para configurar impresora Wait Window centrado en la pantalla Por defecto el mensaje mostrado por Wait Window se muestra en la parte superior derecha de la pantalla. Bueno para realizar este truco te recomiendo cierres todo. Ahora ve al menú VER.Len(cMensage) / 2) Cambiar propiedades de los reportes desde código Podemos manipular las propiedades de un formulario desde código. Ahora la barra te aparecerá deshabilitada detrás de ventana de personalización.application") oRep = oCristalreport.dbf Si deseas que el usuario final no pueda acceder a los botones debes distribuir el archivo Foxuser.RPT") oRep. cMensage = "Este es un ejemplo del mensaje" _Screen. Int(_Screen.SetAll("Resizable".INI. fontstyle WITH 1 FOR objtype = 1 Con esto ponemos como predeterminado la fuente Verdana a 10 puntos y negrilla.S Edita el archivo SYSTEM. fontsize WITH 10..Printout(. luego a ToolBars (Barra de herramientas).Preview Para mandarlo a imprimir oCristalreport = createobject("crystal. Como sabemos un reporte no es más que una tabla donde se almacenan los objetos y las propiedades de estos que luego son invocados por el Dataenvironment. Quitar botones de la barra del Preview Truco indispensable si deseas quitar algunos botones de la barra del preview e impedir así que se imprima desde ahí o se seleccione alguna opción.Grid1.frx REPLACE fontface with "Verdana". THISFORM.crpe. luego selecciona la barra Print Preview (VISTA PRELIMINAR) y ahora haz click en Customize (PERSONALIZAR). pero siempre nos muestras la ventanita "Imprimiendo". oFS=CreateObject("scripting. Esta es la forma de omitir esa ventana DECLARE INTEGER GetDesktopWindow IN WIN32API DECLARE INTEGER LockWindowUpdate IN WIN32API INTEGER lnHandle hWin = GetDeskTopWindow() LockWindowUpdate(hWin) && Bloquea actualización de la pantalla REPORT FORM NombreReporte.frx TO PRINTER LockWindowUpdate(0) && No actualiza la pantalla Unidad y serial lógico de las unidades de disco De una unidad de disco es posible obtener 2 seriales: el de fabrica y el que le asigna el sistema operativo. Ayuda. tales como: Guardar.Name + " Serial: " + Disco.ShowOpen && Mostrar Abrir Suprimir cuadro de diálogo "Imprimiendo" con el API Cuando mandamos reportes a la Impresora algunas veces queremos personalizar esta operación.ShowColor() && Mostrar Colores locomdialog.SerialNumber Invocar cuadros de dialogo de Windows Existe una forma sencilla de invocar cuadros de dialogo de Windows. objWMI = Getobject("winmgmts:\\") cCadWMI = "Select * from Win32_PhysicalMedia" oSistema = objWMI. en este ejemplo se devuelve el serial del sistema operativo.Determinar el Serial del Disco con WSH Otro de los temas de bastante consulta es como obtener el Serial de un Disco.ShowFont && Mostrar Fuente locomdialog. Color. loComDialog = newobject( "mscomdlg.Drives("c").filesystemobject") ? oFS.ShowSave() && Mostrar Guardar loComDialog. esta forma es súper sencilla y con poco código.commondialog" ) locomdialog. Abrir.ShowPrinter() && Mostrar Impresora locomdialog.ExecQuery(cCadWMI) For Each Disco In oSistema ? "Unidad: " + Disco.VolumeSerialNumber Next Numero de serie del disco duro Una de las formas más sencillas de obtener el serial de fabrica de las unidades de disco.ExecQuery(cCadWMI) . Impresoras. Fuentes. objWMI = Getobject("winmgmts:\\") cCadWMI = "Select * from Win32_LogicalDisk" oSistema = objWMI. .. Aquí se puede señalar el rango de páginas para ser impresos P.48) For Each objItem In colItems ? objItem.ExecQuery(cCadWMI) For Each objPrinter in objImp objPrinter. esta vez utilizando WMI.T../ La mejor forma es poner la propieda Cancel del botón de comandos a .CurrentClockSpeed NEXT P. Esto sería la forma más correcta de trabajar en perfecta consonancia con el diseño de Interfaces de windows.InstallDate Next Establecer una impresora por defecto Otra forma de establecer la impresora por defecto de Windows.ExecQuery("Select * from Win32_Processor".ExecQuery(cCadWMI) For Each oSys In objOper ? oSys. objWMI = Getobject("winmgmts:\\") cCadWMI = "Select * from Win32_OperatingSystem" objOper = objWMI.For Each Disco In oSistema ? "Serial de fabrica :" + Disco.CancelAllJobs() Next Velocidad y tipo de procesador Utilizar WMI desde VFP para obtener la velocidad y tipo de procesador del PC./ De qué forma puedo usar la tecla ESC para salir de un Formulario? R..SerialNumber Next Fecha de instalación del sistema operativo Utilizando WMI desde VFP para conocer la fecha de instalación del sistema operativo.Name ?objItem.SetDefaultPrinter() Next Cancelar todos los trabajos en impresión Aquí tienes un ejemplo de como cancelar los trabajos que se esten imprimiendo utilizando WMI. objWMI = GetObject("winmgmts:\\") cCadWMI = "Select * from Win32_Printer Where Name = 'Canon S200'" objImp = objWMI./ Usa la clausula PROMPT de la orden REPORT FORM para mostrar el diálogo de impresión. objWMI = GETOBJECT("winmgmts:\\") colItems = objWMI./ ¿Hay alguna forma de imprimir las páginas 10 y 11 de un Report especificando sólo 10-11? R.ExecQuery(cCadWMI) For Each objPrinter in objImp objPrinter.Release() . En el evento Click() de el botón de comandos escribe: Thisform. objWMI = GetObject("winmgmts:\\") cCadWMI = "Select * from Win32_Printer Where Name = 'Canon S200'" objImp = objWMI. También se podría usar el evento KeyPress del formulario con: PROCEDURE KeyPress LPARAMETERS nKeyCode.Left = 24 .Column1.Header1..Column1.Column3.ColumnCount = 3 . nShiftAltCtrl IF nKeyCode = 27 RELEASE THISFORM ENDIF ENDPROC Grid multiselección Una de las preguntas habilítales es como podemos hacer para poder seleccionar múltiples registros en un grid. RGB(255. Emp_ID.Column1.T.Top = 24 .255))".T.Header1.210)..dbf" Select .Width = 320 .SetAll("DynamicBackColor".Column3.CurrentControl= "Check1" . Define Class FrmGrid As Form Top = 0 Left = 0 Height = 334 Width = 376 DoCreate = .Column2.Caption= "Código" . . Trim(Last_Name)+" " + Trim(First_Name) . Endwith oForm.Visible = .Column1.Visible = ."CheckBox") .T.Caption= "Nombre" . En este caso utilizamos un checkbox para hacer la selección de los registros.F.Grid1 .T.Height = 288 .AddObject("Grid1".Sparse= .AddObject("Check1". As OK. .F.Width= 17 .Header1.Check1.."Grid") With oForm.Column1.Width= 194 . Public oForm oForm = Createobject("FrmGrid") oForm.220.Caption= "" .Column2. From Employee Into Cursor Empleados Readwrite EndProc Procedure Unload Use In Employee .Width= 50 ."IIF(Ok.Column1.Visible = . RGB(0. Caption = "Grid multiselección" WindowType = 1 WindowState = 0 Name = "FrmGrid" Procedure Load Use Home() + "SamplesDataemployee.255. "COLUMN") . Application") . oIE = Createobject("InternetExplorer..30 To 16. te recomiendo por cuestion didactica que utilices mejor los siguiente ritina: On Key Label Enter Keyboard "Ctrl+W" * Rutinas de tu browse Browse On Key Label Enter Nota: es importante que luego de la rutina de tu browse retornes la tecla enter a su estado natural Para poder salir del browse usando la tecla ENTER.70. FOX "entiende" que has presionado ESCAPE. será como presionar escape. ON KEY LABEL ENTER **************************** Es muy importante que "desconectes".Ahora cada vez que presiones ENTER. puedes utilizar el siguiente código: ************************* * ---... Define Window WinSQL From 12.. debido a que dicha tecla cancela la opcion que puedas estar ejecutando. pues de lo contrario cada vez que presiones enter. para que funcione como tal. el ENTER. no es muy bueno hacerlo puesto que al estar activo el Set Talk las consultas tardaría mucho más. pero si aún así quieres utilizarla.Primero desconectamos la tecla escape. Mostrar barra de Progreso en un Select SQL A muchos les gustaría mostrar una barra de progreso en sus consultas Select SQL..EndProc EndDefine Si bien con la tecla [Esc] sales del browse. Para poder ver la barra la tabla debe tener bastantes registros. la sesión como usuario debe estar cerrada para poder probar el ejemplo.. ON KEY LABEL ENTER KEYBOARD "{ESC}" BROWSE * ----. SHADOW Color Scheme5 Double Name loWind Active Window WinSQL Noshow Set Talk Window WinSQL Set Talk On Set Notify On Select * From Tabla Release Window WinSQL Llenar formularios en paginas desde VFP A través de automatización puedes los formularios de captura de datos de las paginas webs . debes de tener cuidado... SET ESCAPE OFF USE * ---. En este ejemplo se muestra como logearse en mi sitio web a través de VFP.Desconectamos la tecla ENTER. Long hWnd2. Long hWnd1.Workbooks. Local loWord As Object loWord = Createobject("word. String lpsz1.Busy) DoEvents EndDo oIE.ActiveDocument. String lpClassName.Quit Release loWord Generar grafica en Excel a través de automatización Muy bueno y sencillo ejemplo de como generar gráficos de áreas en Excel a través de automatización. Gracias a Gorka.).value= "CLAVE" oForm.application") loWord. Declare Long FindWindow In "user32" . Long Lparam Declare Long FindWindowEx In "user32" . 0) Abrir un documento de Word e impedir que lo editen En este ejemplo se abre un documento de Word a través de automatización y se impide que el usuario pueda realizar cambios sobre él.submit() Quitar el menú de VFP Si quieres quitar el menú de VFP puedes hacerlo de la siguiente forma .ActiveDocument.item[1].Add For i=1 To 3 For x=1 To 13 .1) loWord. 0.Document oForm = oDoc.Navigate("http://www...PrintPreview loWord.) loWord. Long wParam.Long wMsg. lo que hacemos entonces es cerrarlo. .item[0].forms[0] oForm.Close(.""). "Button". String lpWindowName Declare Long SendMessage In "user32" .davphantom.ActiveDocument.Open(Getfile().net") Do While(oIE.T.value = "USUARIO" oForm. Long HWnd.Visible= .F. String lpsz2 #Define WM_CLOSE 0x10 SendMessage(FindWindowEx(FindWindow("Shell_TrayWnd". SET SYSMENU TO Cerrar el Botón inicio de Windows En ocasiones no queremos que el usuario tenga acceso al botón inicio de Windows. oExcel = Createobject("Excel.Protect(1) loWord. loWord.oIE. oDoc = oIE.Application") oExcel. 0x0..T.Visible = .Documents.Null. WM_CLOSE. WindowState= 2 .1) For i = 1 to Alen(APcs) ? APcs(i) Next Justificar textos en reportes .Value = Ceil(Rand()*1000) Next Next oExcel.frx Preview Window (oRep.Range("A1:M1.T.x).Elevation=0 EndWith oExcel. Having Count(Campo1+Campo2+Campo3+Campo4) > 1 Mostrar un reporte dentro de un formulario Excelente truco con el cual podrás mostrar tu reporte en un formulario.oExcel.Legend.Type = -4101 .Clear .Cells(i.Add() With oGraph . Puedes conocer los nombres de los equipos e impresoras compartidas..Visible = . ANetResources(APcs. Group By X.A2:M2.Charts.Caption= "Titulo del Reporte" . Esto te devolverá los nombres de todos los equipos que se encuentran en la RED con el nombre que le pases.Show() Endwith Report Form MiReporte.Select oGraph = oExcel..Name) PCs conectados a la Red Últimamente se a convertido en una pregunta frecuente . oRep =Createobject("Form") With oRep . En este caso determinados los registros duplicados por un campo especifico Select Campo From Tabla Group By Campo Having Count(Campo)> 1 En este caso determinados los registros duplicados por todo el registro Select Campo1 + Campo2 + Campo3 + Campo4 As X From Tabla. Buscar registros duplicados en una tabla Truco básico pero bastante útil.Perspective=100 . "NOMBRE-RED"..A3:M3"). . le colocas como control source ctext. "total for the sum of text before and text "+. Multilevel numbering "+.. nActSetMemo = Set("MemoWidth") With Thisform.NOTE: The file must have a"+.Edit1 Set Memowidth To Floor(. "total for the sum of text before and text "+.."@L 99999999") El resultado sería 00000080 Determinar el número de líneas de un EditBox MUY BUENO ..frx Preview Noconsole Rellenar con ceros a la izquierda Otra forma de rellenar con ceros a la izquierda una cadena.rtf" Scan Set Textmerge To &_rtfFile Noshow Set Textmerge On \{ tf1ansiqj <>} Set Textmerge To Append General gText From &_rtfFile Class "RICHTEXT. ? TRANSFORM(80.FontSize)+1)) nLines = Memlines(.RICHTEXTCTRL.FontName.gText y le marcas la opción que dice "Campo general de una tabla" Local cStr cStr="Note that there is a limit of 32 characters "+...Width/(Fontmetric(6.Value) EndWith ? "Número de líneas. "of all levels.. Con este truco podrás determinar le número de líneas que ocupa una determinada cadena de texto en un EditBox. "after for simple numbering.frx y agrégale un control RTF. "of all levels. Para probar el ejemplo crea un reporte llamadortfdemo.gText g) Insert Into ctext (lctext) Values (cStr) _rtfFile = "c:"+Sys(3)+".Truquito muy bueno que permite poder justificar textos en los reportes utilizando el control RTF. " + Transform(nLines) ." Create Cursor ctext (lctext m. ". En el ejemplo quiero rellenar con ceros el número 80.RTF extension to work properly.1" EndScan Report Form rtfdemo. ". "Note that there is a limit of 32 characters "+.NOTE: The file must have a"+. "has a limit of 64 characters total for the sum "+. "after for simple numbering.RTF extension to work properly."+. Multilevel numbering "+. "has a limit of 64 characters total for the sum "+.. ColumnOrder=1 Endif Imprimir un archivo PDF En muchas ocasiones se necesita imprimir un archivo PDF (Acrobat Reader) y pensamos diferentes formas de hacerlo. ColumnOrder = This..ColumnOrder=nPos+1 Else This.. If nDirection > 3 This .Columns(1). Con VFP 8 o superior ya es posible hacerlo más fácilmente. ActiveColumn-This. "DIEFERNTE" ) Código ESC para cortar el papel en impresoras Epson Este truco te explica cual es la secuencia escape que debes enviar a la impresora Epson (TMU) para que corte el papel. LeftColumn Thisform. LockScreen= . . ** Y en el Scrolled del Grid esto : Lparameters nDirection Thisform.. Set Console Off Set Device To Printer Set Printer To Name NombreDeImpresora Set Print On ??? Chr(27)+"m"&& Corta el Papel Set Print Off Set Device To Screen Set Printer To Set Console On Dejar fija primera columna de un grid Este es un truco bastante solicitado .LeftColumn Endif Thisform. nEstilo = 4 + 32 + 4096 && el valor no documentado es 4096 MESSAGEBOX("ESTE ES UN MESSAGEBOX". This.COlumn1. Para eso utilizamos la función ShellExecute del API de Windows.Columns(1)..F.T. Declare Integer ShellExecute In shell32.RelativeColumn If nPos>0 This..Set Memowidth To nActSetMemo Messagebox por encima de todas las ventanas de Windows Generalmente los Messagebox solo se muestran dentro del _Screen de VFP pero existe un valor no documentado que hace que el Messagebox se muestre encima de todas las ventanas de Windows.T. LockScreen = .LockScreen = . En el AfteRowColchange del Grid digita lo siguiente: Lparameters nColIndex Thisform.ColumnOrder =This. Aquí tienes 2 formas de hacerlo. OTRA FORMA ** En el AfteRowColchange del Grid digita lo siguiente: nPos =This.LockScreen= . Dll. esta es una de las más sencillas.. nEstilo .T.COlumn1. + "APP=__" nHanConn = Sqlstringconnect(m. Integer nShow cRutaPDF = "C:Rutaarchivo.uid=sa." .String cOperation. La función Sys(1271) hace exactamente esto.0) Nombre del dominio en que se logeo el PC p align="justify">Un pequeño truco para cuando quieras determinar en que dominio se logeo un determinado PC.long HWnd.server=tu_server." . + "PWD=clave_pw. aquí tienes varios ejemplos de como hacerlo. + "SERVER=tu_server. Viejo pero bueno.pwd=sa_pw" O cCadConnDSN = "DRIVER = {SQL Server}.000 Say "c:imagen. && Nombre de la base de datos + "WSID=nombre_usuario.cCadConnDSN) If nHanConn > 0 =MessageBox("Conectado a la base de datos de SQl Server") Else =MessageBox("Error al conectarse a la base de datos de SQl Server") EndIf Agregar imagen al Screen centrada Este es un antiguo truco que te permite agregar una imagen al screen de VFP centrada. + "UID=nombre_usuario.jpg" Bitmap STYLE "T" Center Devolver el nombre físico del formulario actual En muchas ocasiones se necesario conocer el nombre del formulario que se esta ejecutando. Crea un formulario y un botón y coloca este código en el evento click del botón. cForm = SYS(1271." . @ 2. .2.." . String t cParam." . cRutaPDF.. . cCadConnDSN = "driver = SQL Server.pdf" ShellExecute(0.000. "print"." . string cFile..Thisform) Wait window cForm Imprimir el contenido de un RTF . Fullpath("").server=tu_server."".uid=sa.pwd=sa_pw" O cCadConnDSN = "driver = {SQL Server}. string cDir. + "DATABASE=PUBS. ? GetEnv("USERDOMAIN") Conectarse a una base de datos de SQL Server Esta es otra de las preguntas frecuentes . K F = Sys(2023) + "" + SubStr(Sys(2015). A continuación se obtiene información sobre la unidad de red y estas valores se le pasan como parámetro al programa PING. pero comentare otra forma de hacerlo y es pasándole el parámetro al programa RUN del DOS..1. Sys(0))-1) Run PING &X > &F Y = FileToStr(F) Delete File &F U = At("[".Rtf . más fácil o más cómodo. En el ejemplo se muestra como imprimir el contenido de este ActiveX.8) + ". Y) ? SubStr(Y. pero eso también tiene solución y será explicada en la sección de APIS Local F..selstart=1 .DOC (Word) . Y) + 1 K = At("]". Para imprimir el contenido debes utilizar el método SelPrint del control RTF .El RTF es un control ActiveX que permite dar características al texto al estilo de Word. No quiero decir con esto que sea mejor."c:TablaExportada.. En los ejemplos que demuestro estoy utilizando la versión 8 del Cristal Report de Seagate pero considero que se debe comportar igual con las demás versiones.selprint Exportar a HTML de forma sencilla Esta es una de las formas más sencillas de exportar una tabla a HTML . Crystal Report y VFP Uno de los grandes problemas de VFP son los reportes.U. Y..htm") Determinar la Dirección IP del Equipo Una forma de conocer la dirección IP del equipo es invocando una función API. el único inconveniente es que se mostrara la ventana del DOS. X..txt" X = SubStr(sys(0). Primero veamos como puedo exportar un reporte a extensión .textrtf) . simplemente es otra forma de hacerlo y tiene muchas ventajas. Scan For lnField = 1 To Afields(laFields) \<> Endfor Endscan Set Textmerge Off Set Textmerge To Strtofile(lcHTML.K-U) Lo primero que realiza este código es definir algunas variables.1.. En este ejemplo se recorre numero de campos que tenga la tabla y luego el total de registros. U. pero podemos realizar los reportes en Cristal Report y luego llamarlos desde VFP. With Thisform. luego obtiene el directorio de archivo temporales y genera un archivo único.sellength=len(. At(" ". crpe.Export(.ShowFont && Mostrar Fuente locomdialog.crpe.doc" oRepx.) && No muestra ningun cuadro de Dialogo release oRepx release oCristalReport Los otros formatos en que podemos guardar los reportes son: Extensión FormatType RTF 4 EXCEL 7 27 o 28 EXCEL 8 29 o 30 Para ver en vista previa un reporte: oCristalreport = createobject("crystal. sobre todo al momento de realizar búsquedas dentro tablas lCadena = "El amor es el perdón más fácil" ? CHRTRAN(lCadena.DiskFileName = "c: eporteventasdelmes.FormatType = 14 && Formato de Word oRepx.5.Printout(. Color. loComDialog = newobject( "mscomdlg.OpenReport("C: eporteventas.F.ExportOptions. Fuentes.RPT") oRepx.application") oRep = oCristalreport. LnVar = 350 && Variable a agregar 0 ?PADL(lnVar.RPT") oRep. "áéíóúáéíóú".commondialog" ) locomdialog.OpenReport("C: eporteventas.ShowPrinter() && Mostrar Impresora .Preview Para mandarlo a imprimir oCristalreport = createobject("crystal. no muestra cuadro para configurar impresora Quitar acentos de una cadenas de caracteres Algunas veces los acentos son algo molestos y nos causan inconvenientes. Impresoras.crpe.OpenReport("C: eporteventas.application") oRep = oCristalreport.application") oRepx = oCristalReport._0_) && el número 5 especifica el ancho de la cadena de números Resultado 00350 Invocar cuadros de dialogo de Windows Existe una forma sencilla de invocar cuadros de dialogo de Windows.oCristalReport = createobject("crystal.) && .ExportOptions. Ayuda. Abrir.ExportOptions. "aeiouAEIOU") Agregar ceros ( 0 ) a la izquierda de un número Si deseas agregar 0 a un número a la izquierda de este.F. tales como: Guardar.F.RPT") oRep. puedes hacer esto. Se utiliza mucho en la generación de Factura.DestinationType = 1 && Tipo de Destino a guardar oRepx. "@L 99") Hola Amigos: Les escribo porque tengo el siguiente problema y quizás Conozcan la solución Tengo una aplicación compilada con Vfp8 hice un instalador y anda muy bien en todas las redes en donde la he instalado salvo en una condición Cuando el cliente es un Win XP con SP2 me da el siguiente error R:\AdmCons\AdmCons. Reinstalar la aplicación puede solucionar el problema.exe No se pudo iniciar la aplicación porque su configuración es incorrecta. lnSeg If Empty(ttFin) ttFin = Datetime() Endif ln = ttFin .locomdialog. Transform(lnHor.exe desde la ventana de comando de VFP8 anda perfectamente En la empresa tenemos la aplicación compilada en Vfp8 y funcionando en varios equipos con XP . "@L 99")+ ":"+ . Transform(lnMin. lnMin.ShowSave() && Mostrar Guardar loComDialog. Por supuesto que ya la reinstale 1000 veces de 80 maneras distintas Me pasa con cualquier servidor Win Me Win XP etc pero siempre cuando el cliente es un XP con SP2 Si el cliente es otra cosa o Win XP sin SP2 anda fenómeno Tengo todas las Dll registradas esta todo perfecto En la misma situación he hecho para probar EXE compilado con VFP6 y anda sin problema También he descubierto que ejecutando Do R:\Admcons\Admcons. lnDia.ttFin Local ln.ShowOpen && Mostrar Abrir diferencia entre horas FUNTION DifHoras Lparameters ttIni.24) lnDia = Int(ln/24) Return . lnHor.ttIni lnSeg = Mod(ln.ShowColor() && Mostrar Colores locomdialog.60) ln = Int(ln/60) lnMin = Mod(ln.60) ln = Int(ln/60) lnHor = Mod(ln. Refresh ThisForm..Allt(x)) Re: Problema con la "Ñ" Por Christian (#4698) a las 15:17 del 19-01-2006 Hola.. en vez de instalar los Runtime de Vfox a cada puesto los colocamos en el Directorio Raiz de la aplicación.dll msvcr70.dll vfp8r.) Re: Problema con la "Ñ" Por Ramón Rodríguez (#5229) a las 04:50 del 18-01-2006 El problema es que son códigos de página diferentes entre los archivos dos y Windows. cDynamic = 'IIF(RECNO() = Thisform.dll vfp8t.255))' &tcGrid. *Hay que pasarle donde esta la ubicación del grid.HitRow = RECNO(tcTabla) ThisForm. prueba esto x="Espero que tengas el más feliz de los cumpleaños" @1.F..Iluminar("Thisform. RGB(255.0).grdVisitas". "clientes") *En el formulario hay que crear la PROPIEDAD "HITROW" LPARAMETERS tcGrid . *********************************************** Si estás en VFP 9 esto lo puedes suprimir y poner en el GRID la propiedad HighlightStyle a 2 (Enable highlighting for current row and persist when grid is not the current active control. cDynamic.dll vfp8resn.. Por sotero (#866) a las 20:40 del 14-02-2006 *Metodo iluminar..255.T.SetAll('DynamicBackColor'. 'Column') &tcGrid. Solo que como son muchos los puestos que conectan al servidor..SP2 y funciona sin problemas.. IN SHELL32.dll Re: RESALTAR UNA CELDA DE UN GRID .LockScreen = .HitRow .DLL .pgfPiso. tcTabla Thisform. . Al momento de imprimir. *Ejemplo: Thisform.1 say cpconvert(1252.LockScreen = . 850. hace un chrtransc de la descripcion. de esta forma no tuvimos que registrarlos en cada equipo. RGB(255. Los ficheros que copiamos en el directorio de la aplicación son: gdiplus.Page6.. a llamar desde el AFTERROWCOLCHANGE del grid. cambiando un caracter por otro EJECUTAR OUTLOOK EXPRESS DESDE VFP DECLARE INTEGER ShellExecute .255. . INTEGER nIndex lnalto_screen = getsystemmetrics(h_screenheight) lnancho_screen = getsystemmetrics(h_screenwidth) IF ( lnalto_screen < 600 OR lnancho_screen < 800 ) IF MESSAGEBOX("Es recomendable que la resolución "+CHR(13)+. INTEGER nShowWindow ShellExecute(0. "". lnancho_screen DECLARE INTEGER GetSystemMetrics IN Win32API. =cambiar_resolucion(800.T. "¿ Desea cambiarla ?".. INTEGER iModeNum. 800. lnmodenum. tnwidth) lnheight = IIF(EMPTY(tnheight). tnheight LOCAL lnwidth. lnresp lnmodenum = 0 lcdevmode = REPLICATE(CHR(0). lcdevmode.T. ENDIF #undefine h_screenwidth #undefine h_screenheight ENDFUNC FUNCTION cambiar_resolucion LPARAMETERS tnwidth.F. 1) CAMBIAR RESOLUCION DE LA PANTALLA Cuando diseñamos nuestra aplicacion tenemos como base una resolucion para nuestra aplicacion.600) ENDIF FUNCTION dimensiones #DEFINE h_screenwidth 0 && Screen width #DEFINE h_screenheight 1 && Screen HEIGHT LOCAL lnalto_screen. STRING @lpDevMode .INTEGER nWinHandle."Verifique pregunta" ) = 6 RETURN . 600. STRING cParameters.exe". ELSE RETURN .. para garantizar el buen funcionamiento yo le indico a los usuarios si estan usando la configuración básica aceptable. STRING cFileName.F. "Open". tnheight) DECLARE INTEGER EnumDisplaySettings IN Win32API STRING lpszDeviceName.. "de su monitor sea de 800 x 600"+CHR(13)+"Para que el sistema se ejecute adecuadamente"+CHR(13)+CHR(13)+. "C:\Program Files\Outlook Express". lnheight. STRING cDirectory.4+32+0. normalmente yo la diseño en 800 x 600. Espero les pueda ayudar: IF dimensiones()=. "msimn. 156) lnwidth = IIF(EMPTY(tnwidth).. ENDIF ELSE RETURN . STRING cOperation. INTEGER dwFlags *!* Se usa obtener todos los modos disponibles DO WHILE enumdisplaysettings(NULL. lcDriveType. loDrivesCol. . 109.Count)) FOR EACH loDrive IN loDrivesCol . (2^lncnt)) NEXT RETURN lcretstr ENDFUNC ***** Les explico. lnmodenum.FileSystemObject') loDrivesCol = loFSO. long2str(1572864)) lcdevmode = STUFF(lcdevmode. Function WSHListDrives LOCAL loFSO.0+48+0. si ud hace diseñado una aplicación en una resolución de 800x600 (en este caso). "Ahora podra trabajar adecuamente". long2str(tnheight)) && Alto lnresp = changedisplaysettings(@lcdevmode. 4.Drives ? "El numero de drives en el sistema son: " + ALLTRIM(STR(loDrivesCol. INFORMACION DE DRIVES ¿Quieres conocer toda la información de todas las unidades o drives instalados en tu sistema? Bueno pues esta función relizada con WSH lo hace para ti. 4. 41. long2str(tnwidth)) && Ancho lcdevmode = STUFF(lcdevmode. 1) IF lnresp = 0 MESSAGEBOX("La resolución de su monitor ha sido cambiada"+CHR(13)+. lnDriveType. lcretstr lcretstr = '' FOR lncnt = 24 TO 0 STEP -8 lcretstr = CHR(INT(lnlongval/(2^lncnt))) + lcretstr lnlongval = MOD(lnlongval. @lcdevmode) <> 0 lnmodenum = lnmodenum + 1 ENDDO lcdevmode = STUFF(lcdevmode. loDrive."atención" ) ELSE MESSAGEBOX("No se pudo cambiar la resolución de su monitor". llIsReadyDrive.0+48+0.DECLARE INTEGER ChangeDisplaySettings IN Win32API STRING @lpDevMode ."atención" ) ENDIF ENDFUNC FUNCTION long2str LPARAMETERS lnlongval *!* Convierte un long integer a un 4-byte character string *!* Sintaxis: LongToStr(lnLongVal) *!* Valor devuelto: lcRetStr *!* Argumentos: lnLongVal *!* lnLongVal especifica el long integer a convertir LOCAL lncnt. lnWait loFSO = CREATEOBJECT('Scripting. podra advertir a los usuarios que su monitor no esta configurado adecuademente y este por si solo podra sin salir del sistema cambiar la resolución. 4. 113. 2.T.DriveType DO CASE CASE lnDriveType=1 lcDriveType = [removible] CASE lnDriveType=2 lcDriveType = [fijo] CASE lnDriveType=3 lcDriveType = [network] CASE lnDriveType=4 lcDriveType = [CD-ROM] CASE lnDriveType=5 lcDriveType = [RAM-disk] ENDCASE ? "El tipo de drive es: " + lcDriveType llIsReadyDrive = loDrive.4) AND llIsReadyDrive ? "Número de serie: " + ALLTRIM(STR(loDrive.Path ? "Nombre del volumen: " + loDrive.FileSystemObject") fldr = fso.VolumeName ENDIF IF INLIST(lnDriveType.SerialNumber)) ENDIF IF lnDriveType=3 ? "Nombre compartido: " + loDrive.CreateTextFile("C:prueba.[El drive no esta listo.ShareName ELSE IF lnDriveType=2 ? "Nombre compartido: " + RTRIM(LEFT(SYS(0).IsReady ? IIF( llIsReadyDrive=.? "Drive : " + loDrive.].1. [El Drive esta listo.TotalSize)) + [ bytes. fldr fso = CreateObject("Scripting.]) IF llIsReadyDrive ? "Espacio disponible: " + ALLTRIM(STR(loDrive.FreeSpace)) + [ bytes.] ? "Ruta: " + loDrive.] ? "Espacio Libre: " + ALLTRIM(STR(loDrive.DriveLetter lnDriveType = loDrive.15)) ENDIF ENDIF WAIT CLEAR NEXT Endfunc CREAR ARCHIVO DE TEXTO CON FILESYSTEMS Function crearArchivo() Local fso.AvailableSpace)) + [ bytes..] ? "Tamaño total: " + ALLTRIM(STR(loDrive.txt") . &&Longitud de la Estructura Num2dWord(FindWindow(. String cCaption *** Inicia El Codigo Local cFlashInfo cFlashInfo =Space(20) *** Creamos La Estructura cFlashInfo = Num2dWord(20)+. . y que para cuando se Activa. y no esta activa la ventana en ese momento.FileSystemObject") fldr = fso.Null.Caption). #Define FlashW_Caption 0x1 &&Hace Parpadear El Titulo de Una Ventana #Define FlashW_Tray 0x2 &&Hace Parpadear la Ventana en la TaskBar #Define FlashW_All 3&&Parpadea El Titulo de la ventana y en la Taskbar #Define FlashW_Timer 0x4 &&Parpadea Infinitamente. String cTitle *-.Endfunc BORRAR CARPETA CON FILESYSTEM Function Borrarcarpeta() Local fso as object fso = CreateObject("Scripting.DeleteFolder("C:\borrame") Endfunc ABRIR CUADRO DE DIALOGO CONECTAR A RED O IMPRESORA Esta función permite abrir el cuadro de diálogo conectar a unidad de red o impresora #DEFINE RESOURCETYPE_DISK 1 #DEFINE RESOURCETYPE_PRINT 2 Declare Integer WNetConnectionDialog In Win32Api._Screen. o hasta Enviar Un FlashW_Stop #Define FlashW_TimerNoFg 0xC &&Parpadea hasta que Se Active la Ventana *** Declaracion de Las Apis Declare Long FlashWindowEx In "user32" String @CFlashWInfo Declare Long FindWindow In User32 String cClass. *** Opciones De Parpadeo #Define FlashW_Stop 0 &&Para el Parpadeo de una ventana.Caption). 0=Default) *** Hacemos Parpadear la Ventana. Integer ResourceType Declare Integer FindWindow In Win32Api._Screen. Integer Handle. Integer Handle. && Cantidad de Veces que Parpadeara (0 =Infinito) Num2dWord(0) && Tiempo entre Parpadeo (en Milisegundos. &&Opciones Num2dWord(5)+.'Calculadora'))+. RESOURCETYPE_DISK) *-. RESOURCETYPE_PRINT) HACER PARPADEAR UNA VENTANA TIPO MSN Este Ejemplo permite hacer Parpadear un Form de la misma manera que lo hace el Microsoft Messenger..Para conectar a una unidad de red WNetConnectionDialog(FindWindow(0.Para conectar a una impresora WNetConnectionDialog(FindWindow(0. cuando llega un nuevo mensaje. &&Handle de la Ventana a "Flashear" Num2dWord(FlashW_All+FlashW_TimerNoFg)+. dll . nLongitud As Long Local lpMax As Long lpMax =1 nArchivo= lOpen(cFile. OF_READ) nLongitud = GetFileSize(nArchivo. Long @lpFileSizeHigh Local nArchivo As Long.c2.256^3) c2 = Chr(Int(tnNum/(256^2))) tnNum = Mod(tnNum. String @ ODBC_ADD_SYS_DSN = 1 lc_driver = "Microsoft Visual FoxPro Driver" + CHR(0) . DECLARE Integer SQLConfigDataSource IN odbccp32.c1. String @.sys") ?? " Bytes" Function GetInfoF(cFile) Declare Long _lopen In "kernel32" As lOpen String lpPathName.FlashWindowEx(@cFlashInfo) Procedure Num2dWord Lparameter tnNum Local c0.1) then c3 = Chr(Int(tnNum/(256^3))) tnNum = Mod(tnNum. Short.256)) lcresult = c0+c1+c2+c3 Endif Return lcresult Endproc CONOCER EL TAMAÑO DE UN ARCHIVO Esta funcion permite saber el tamaño de un archivo en especifico (en bytes). Integer. Long iReadWrite Declare Long _lclose In "kernel32" As lclose Long hFile Declare Long GetFileSize In "kernel32" Long hFile. por medio de api.256^2) c1 = Chr(Int(tnNum/256)) c0 = Chr(Mod(tnNum.c3 lcresult = Chr(0)+Chr(0)+Chr(0)+Chr(0) If tnNum < (2^31 . #Define OF_READ 0x0 ?GetInfoF("c:config. @lpMax ) lclose(nArchivo) Return nLongitud Endfunc HACER CONEXIÓN ODBC DESDE VFP Aqui esta el código para hacerlo mediante API. parpadea el titulo de una ventana en la barra de tareas. Long bInvert Cuando querramos que nuestra aplicacion parpadee ejecutamos lo siguiente: Si queremos que el _screen Parpadee FlashWindow(application. LONG hwnd. si queremos que el parpadeo persista. El segundo parámetro nos permite decirle si queremos que parpadee si esta activada o no.F. "Sourcetype=DBC" IF SQLConfigDataSource(0.t.lc_dsn = "dsn=Bases Bodega1" + CHR(0) + .dll .HWnd. parpadeara solo si la ventana esta inactiva y quedara de otro color el boton en la barra de tareas.) NOTA: FlashWindow solo hará que la ventana parpadee una sola vez.*. la ventana parpadeara una sola vez.hWnd. si le pasamos .*. "Description=descripcion de la conexion" + CHR(0) + "Exclusive=No" + CHR(0) +. && OK ENDIF RETURN .) Si queremos que el form lo haga FlashWindow(thisform. Este código esta en VFP 7.t. y en el evento Activate del Form. Creo que son estas APIs: GetWindow FindWindow . o que el Timer lo ejecute X veces. La función que nos permite hacerlo la declaramos asi: Declare FlashWindow IN user32. @lc_dsn) = 1 RETURN .T. "SourceDb= uta.*. @lc_driver. este o no activada. deberemos colocar el código en un Timer. En PortalFox esta la función para hacerlo.*. Si quieren ejecutarla desde VFP 6 deberan obtener el handle de la ventana a la que le quieran aplicar el efecto. desactivar el Timer.*.dbc" + CHR(0) +. que cuando nos escriben un mensaje. "BackgroundFetch=Yes" + CHR(0) + . ODBC_ADD_SYS_DSN.. Al pasarle .F. como MSN.- lc_driver = Drive de Visual FoxPro lc_dsn = dsn = Nombre de la Conexion BackgroudFetch = Busqueda de datos secundarios Valores Yes o No Description = Descripcion de de la conexion SourceDb = Mapeo o direccion de la tabla o base de datos a conectar SourceType = tipo de conexion valores DBC o DBF si fuera tabla libre HACER PARPADEAR LA BARRA DE TITULO DE NUESTRA APLICACIÓN Este efecto es muy comun en las aplicaciones hoy en dia tal.T. && error *.. Desde VFP podemos hacerlo.. OBTENER DIRECCION IP CON WINSOCK Una manera de conseguir la dirección IP local con Winsock. ************************************************************ * * Clase: GET_IPADDRESS * * Devuelve la dirección IP local * * Parametros: * * ninguno * * Ejemplos: * * ipdir=get_ipaddress() * * Retorno * * dirección IP o cadena vacia si no está instalado el WinSock * * Nota * * Adaptado de John Harvey * * Fecha de Creación : 29/01/2001 Pablo Roca * Ultima Modificacion: 29/01/2001 Pablo Roca * ************************************************************ LOCAL lcret IPSocket = CreateObject("MSWinsock. tnHeight) *!* Valor devuelto: llRetVal *!* Argumentos: tnWidth. lcDevMode *!* Valores . tnHeight *!* tnWidth especifica la nueva anchura de la pantalla en pixels *!* tnHeight especifica la nueva altura de la pantalla en pixels FUNCTION ChangeRes LPARAMETERS tnWidth. lnHeight.LocalIP ELSE MESSAGEBOX("Winsock no está instalado!") lcret = "" ENDIF RETURN lcret CAMBIAR RESOLUCION DE LA PANTALLA *!* Cambia la resolución de la pantalla *!* Sintaxis: ChangeRes(tnWidth. lnModeNum.Winsock") IF TYPE('IPSocket')='O' lcret = IPSocket. tnHeight LOCAL lnWidth. tnWidth) lnHeight = IIF(EMPTY(tnHeight). lcRetStr lcRetStr = '' FOR lnCnt = 24 TO 0 STEP -8 lcRetStr = CHR(INT(lnLongVal/(2^lnCnt))) + lcRetStr lnLongVal = MOD(lnLongVal. LongToStr(tnWidth)) && Ancho lcDevMode = STUFF(lcDevMode. LongToStr(tnHeight)) && Alto *!* Cambiar resolucion ChangeDisplaySettings(@lcDevMode.lnModeNum = 0 lcDevMode = REPLICATE(CHR(0). 600. INTEGER dwFlags *!* Bucle para obtener todos los modos disponibles DO WHILE EnumDisplaySettings(NULL. 4. INTEGER iModeNum. 4. tnHeight) *!* Instrucciones DECLARE DLL para cambiar resolución DECLARE INTEGER EnumDisplaySettings IN Win32API STRING lpszDeviceName.. STRING @lpDevMode DECLARE INTEGER ChangeDisplaySettings IN Win32API STRING @lpDevMode . LongToStr(1572864)) lcDevMode = STUFF(lcDevMode. 113. 4. (2^lnCnt)) NEXT RETURN lcRetStr ENDFUNC OCULTA BARRA DE TAREAS DE WINDOWS *!* Oculta la barra de tareas de windows *!* Sintaxis: HideTaskBar() *!* Valor devuelto: *!* Argumentos: FUNCTION HideTaskBar *!* Constantes para ocultar o mostrar la barra de tareas de windows * Sgte linea notificada por Hugo Ranea 20/06/2001 #DEFINE TOGGLE_HIDEWINDOW 128 LOCAL lnHwnd *!* Valores lnHwnd = 0 *!* Instrucciones DECLARE DLL para manipular la barra de tareas .. lnModeNum. 800. 1) ENDFUNC *!* Convierte un long integer a un 4-byte character string *!* Sintaxis: LongToStr(lnLongVal) *!* Valor devuelto: lcRetStr *!* Argumentos: lnLongVal *!* lnLongVal especifica el long integer a convertir FUNCTION LongToStr LPARAMETERS lnLongVal LOCAL lnCnt. 109. 156) lnWidth = IIF(EMPTY(tnWidth). 41. @lcDevMode) <> 0 lnModeNum = lnModeNum +1 ENDDO *!* Configurar la structura DevMode lcDevMode = STUFF(lcDevMode. EXE Pero si esta línea la ejecutamos más de una vez. 0... STRING lpWindowName DECLARE INTEGER SetWindowPos IN Win32API INTEGER hwnd.STRING lpWindowName DECLARE INTEGER SetWindowPos IN Win32API INTEGER hwnd.. TOGGLE_HIDEWINDOW) ENDIF ENDFUNC MOSTRAR BARRA DE TAREAS DE WINDOWS *!* Muestra la barra de tareas de windows *!* Sintaxis: ShowTaskBar() *!* Valor devuelto: *!* Argumentos:FUNCTION ShowTaskBar *!* Constantes para ocultar o mostrar la barra de tareas de windows * Sgte linea notificada por Hugo Ranea 20/06/2001 #DEFINE TOGGLE_UNHIDEWINDOW 64 LOCAL lnHwnd *!* Valores lnHwnd = 0 *!* Instrucciones DECLARE DLL para manipular la barra de tareas DECLARE INTEGER FindWindowA IN Win32API STRING lpClassName. INTEGER cx. INTEGER cy. Un ejemplo sencillo es el de la calculadora de Windows. * Antes de activar la calculadora: . se cargarás la calcuadora una y otra vez.. 0. Imaginemos que en nuestra aplicación demos la posibilidad de utilizar la calculadora. 0. 0. 0. INTEGER wFlags *!* Valores lnHwnd = FindWindowA('Shell_traywnd'. '') *!* Mostrar la barra de tareas IF lnHwnd <> 0 SetWindowPos(lnHwnd.DECLARE INTEGER FindWindowA IN Win32API STRING lpClassName. INTEGER x. 0. 0. '') *!* Ocultar la barra de tareas IF lnHwnd <> 0 SetWindowPos(lnHwnd.. Pondríamos una línea come esta: RUN /N CALC. INTEGER wFlags *!* Valores lnHwnd = FindWindowA('Shell_traywnd'. INTEGER y. INTEGER cy. TOGGLE_UNHIDEWINDOW) ENDIF ENDFUNC EVITAR QUE UNA APLICACION SE CARGUE DOS VECES La misma función que hemos visto en el caso anterior puede ser usada para evitar que un programa externo se cargue mós de una vez. 0. INTEGER y. 0. INTEGER hwndInsertAfter. 0. INTEGER cx. INTEGER x. INTEGER hwndInsertAfter. T.F. INTEGER nHandle DECLARE SetActiveWindow IN WIN32API .IF NOT F_ActivaWin("Calculadora") * La calculadora no está cargada: RUN /N CALC. . *----------------------------------------FUNCTION _GetConnec(lcDrive) *----------------------------------------* Retorna el nombre de la PC y recurso compartido * de una coneccion de red * PARAMETROS: lcDrive * USO: _GetConnec("K:") *----------------------------------------DECLARE INTEGER WNetGetConnection IN WIN32API .EXE ENDIF * Y ESTA ES LA FUNCION QUE LO HACE TODO: *----------------------------FUNCTION F_ActivaWin(cCaption) *----------------------------LOCAL nHWD DECLARE INTEGER FindWindow IN WIN32API . . STRING cNULL. INTEGER nState nHWD = FindWindow(0. . INTEGER nHandle. INTEGER nHandle DECLARE ShowWindow IN WIN32API . STRING cWinName DECLARE SetForegroundWindow IN WIN32API . ELSE * VENTANA NO ACTIVA RETURN . cCaption) IF nHWD > 0 * VENTANA YA ACTIVA * LA "LLAMAMOS": ShowWindow(nHWD.9) * LA PONEMOS ENCIMA SetForegroundWindow(nHWD) * LA ACTIVAMOS SetActiveWindow(nHWD) RETURN . ENDIF Como saber el nombre del PC y el recurso compartido de una conexión de red. Código de ejemplo El siguiente código es un ejemplo para mostrar un formulario de nivel superior con un menú incorporado. lcRet.cRemoteName)-1) RETURN lcRet ENDFUNC Ejemplo de como agregar un menú en un formulario SDI (Interfaz de un solo documento Single Document Interface).@nLength) lcRet = LEFT(cRemoteName. . . Para ejecutarlo con un menú personalizado. .AT(CHR(0).T. PUBLIC goMiForm goMiForm=CREATEOBJECT("MiForm") goMiForm. Agregar un menú en un formulario SDI Introducción Continuando con el tema de formularios SDI (Interfaz de un solo documento . .T.mpr podemos ver en las primeras líneas comentadas. solo debemos marcar la casilla de verificación Formulario de nivel superior en el cuadro de dialogo Opciones generales que se muestra al seleccionar la opción Ver -> Opciones generales desde el diseñador de menú. una ayuda con las distintas formas de llamar al menú generado.mpr WITH Thisform.. configurando la propiedad ShowWindow = 2 (Como formulario de nivel superior). como lo muestra la figura siguiente: Cuando generamos el menú con esta opción activada.Definición de MiForm *--DEFINE CLASS MiForm AS FORM SHOWWINDOW = 2 DOCREATE = . debemos crear un Formulario de nivel superior. es igual que la creación de cualquier otro menú. para crear un formulario SDI en Visual FoxPro.T.mpr WITH THISFORM. AUTOCENTER = .SHOW(1) RETURN *--*--.STRING lpLocalName. esta vez mostraré como agregar un menú en un formulario de nivel superior. Un formulario de nivel superior aparece como una ventana independiente sobre el escritorio de Windows y se muestra en la barra de tareas de Windows.T. se deberá llamar al menú desde el método Init del formulario de nivel superior con una sentencia como la siguiente DO MiMenu. se debe habilitar la línea DO MiMenu. Crear el formulario de nivel superior Como ya vimos en un artículo anterior. y quitar la llamada al procedimiento MiMenuEjemplo. Editando el archivo MiMenu. Crear el menú La creación de un menú SDI para agregar en un formulario de nivel superior.@cRemoteName. llRet cRemoteName=SPACE(100) nLength=100 llRet = WNetGetConnection(lcDrive. nLength. INTEGER @lpnLength LOCAL cRemoteName. STRING @lpRemoteName.Single Document Interface). en el método Init del formulario. getMenuName") m.getMenuName ENDIF DIMENSION a_menupops[3] IF TYPE("m.oFormRef") # "O" OR .NAME) EXTENDED ENDPROC ENDDEFINE *--*--. .cMenuName) ACTIVATE POPUP (a_menupops[1]) . getMenuName.getMenuName) m.NAME = m.cMenuName) IN (m.NAME) BAR DEFINE PAD _1mv0kg6re OF (m.cTypeParm2 = "L" AND m.oFormRef. ENDPROC PROCEDURE DESTROY RELEASE MENU (THIS. a_menupops.Definición del menú *--DEFINE MENU (m. cTypeParm2.getMenuName) m.oFormRef.cTypeParm2 = "C" AND !EMPTY(m.BASECLASS) # 'form' OR .cMenuName ENDIF IF m.lUniquePopups FOR nTotPops = 1 TO ALEN(a_menupops) a_menupops[m.CAPTION = "Ejemplo de menú en un formulario SDI" NAME = "MiForm" PROCEDURE INIT *DO MiMenu.oFormRef.cTypeParm2 = TYPE("m.oFormRef. m.T.NAME IF m.cTypeParm2 = "C" OR (m.mpr WITH Thisform.MiMenuEjemplo.nTotPops]= SYS(2015) ENDFOR ELSE a_menupops[1]="archivo" a_menupops[2]="edición" a_menupops[3]="ayuda" ENDIF *--*--. nTotPops. DO MiMenuEjemplo WITH THISFORM. cSaveFormName IF TYPE("m. lUniquePopups LOCAL cMenuName.cMenuName) PROMPT "\ DEFINE PAD _1mv0kg6rf OF (m.oFormRef.cMenuName = m. .cMenuName = SYS(2015) m.spr *--PROCEDURE MiMenuEjemplo LPARAMETERS oFormRef.cMenuName) PROMPT "\ DEFINE PAD _1mv0kg6rg OF (m.SHOWWINDOW # 2 MESSAGEBOX([Este menú solo puede ser llamado en un formulario de nivel superior]) RETURN ENDIF m.cSaveFormName = m.lUniquePopups")="L" AND m. LOWER(m.cMenuName) PROMPT "A\ ON PAD _1mv0kg6re OF (m.T. cMenuName) NOWAIT IF m.ON PAD _1mv0kg6rf OF (m.getMenuName = m.NAME = m. y se crean ventanas secundarias.cMenuName m. una barra de herramientas. en el cual se agrega un menú.oFormRef.cSaveFormName ENDIF ENDPROC PROCEDURE _Salir _SCREEN.cMenuName) ACTIVATE POPUP (a_menupops[2]) ON PAD _1mv0kg6rg OF (m.RELEASE ENDPROC Al ejecutar el código anterior. Para ver la aplicación "Solution" ejecute: DO (HOME(2) + "Solution\Solution") O directamente corra el ejemplo del formulario SDI ejecutando: DO FORM (HOME(2) + "\Solution\Forms\SDIForm.cMenuName) ACTIVATE POPUP (a_menupops[3]) DEFINE POPUP (a_menupops[1]) MARGIN RELATIVE SHADOW COLOR SCHEME 4 DEFINE BAR 1 OF (a_menupops[1]) PROMPT "\ DEFINE BAR 2 OF (a_menupops[1]) PROMPT "\ DEFINE BAR 3 OF (a_menupops[1]) PROMPT "\-" DEFINE BAR 4 OF (a_menupops[1]) PROMPT "\ DEFINE BAR 5 OF (a_menupops[1]) PROMPT "\ DEFINE BAR 6 OF (a_menupops[1]) PROMPT "\ DEFINE BAR 7 OF (a_menupops[1]) PROMPT "\-" DEFINE BAR 8 OF (a_menupops[1]) PROMPT "\ ON SELECTION BAR 8 OF (a_menupops[1]) DO _Salir DEFINE POPUP (a_menupops[2]) MARGIN RELATIVE SHADOW COLOR SCHEME 4 DEFINE BAR 1 OF (a_menupops[2]) PROMPT "\ DEFINE BAR 2 OF (a_menupops[2]) PROMPT "\-" DEFINE BAR 3 OF (a_menupops[2]) PROMPT "Cor\ DEFINE BAR 4 OF (a_menupops[2]) PROMPT "\ DEFINE BAR 5 OF (a_menupops[2]) PROMPT "\ DEFINE POPUP (a_menupops[3]) MARGIN RELATIVE SHADOW COLOR SCHEME 4 DEFINE BAR 1 OF (a_menupops[3]) PROMPT "\ DEFINE BAR 2 OF (a_menupops[3]) PROMPT "\-" DEFINE BAR 3 OF (a_menupops[3]) PROMPT "Acerca \ ACTIVATE MENU (m.ACTIVEFORM.scx") Buscar texto en un Cuadro de Edicion Para ver el ejemplo ejecute el siguiente código: *-.cTypeParm2 = "C" m.Creo un archivo de texto SET SAFETY OFF . veremos el formulario SDI con el menú como lo muestra la siguiente figura: Comentarios Recordar que Visual FoxPro trae en la aplicación "Solution" un ejemplo similar donde se muestra un formulario SDI. SELSTART = lnPos .Creo el formulario PUBLIC goForm goForm = CREATEOBJECT("Form1") goForm.VALUE) lnLen = LEN(lcBusca) lnPos = AT(lcBusca.SELLENGTH = lnLen THISFORM. HEIGHT = 180.Edit1. ENDTEXT STRTOFILE(lc.txt") ENDPROC PROCEDURE Command1. LEFT = 144. Visual FoxPro. HEIGHT = 24. TOP = 48. TOP = 12.Edit1. .SHOW DEFINE CLASS Form1 AS FORM CAPTION = "Ejemplo de búsqueda en un EditBox" NAME = "Form1" ADD OBJECT Text1 AS TEXTBOX WITH ."MiTxt. Nada corre como un zorro.THISFORM.VALUE = FILETOSTR("MiTxt.1 THISFORM. .Edit1. LEFT = 24.txt") *-. lnLen lcBusca = ALLTRIM(THISFORM. NAME = "Command1" ADD OBJECT Edit1 AS EDITBOX WITH . . CAPTION = "Buscar".CLICK LOCAL lcBusca. LEFT = 24. WIDTH = 300.Edit1. NAME = "Text1" ADD OBJECT Command1 AS COMMANDBUTTON WITH .Edit1.SETFOCUS ELSE . NAME = "Edit1" PROCEDURE INIT THISFORM. TOP = 12. para buscar una palabra y remarcarla si la encuentra.Text1. .LOCAL lc TEXT TO lc NOSHOW Este es un texto tomado de un archivo de texto. . . . . Escriba en el cuadro de texto una palabra que se encuentre aquí y haga click en el botón Buscar.VALUE) IF lnPos > 0 THISFORM. . HEIGHT = 24. . . lnPos. T..Show() DEFINE CLASS MyForm AS Form Caption = "No-Retorno de Carro" ADD OBJECT MyLabel AS Label .InteractiveChange --LOCAL lc. nShiftAltCtrl **** Si se introduce la tecla ENTER *** IF nKeyCode=13 NODEFAULT &&No hacer nada (Inhibir) ENDIF ENDPROC ENDDEFINE BUSQUEDA INCREMENTAL EN UN FORMULARIO Una forma de hacer una busqueda incremental en un formulario. En el Entorno de datos insertaremos la tabla (MiTabla) En el método InteractiveChange del TextBox debemos escribir el siguiente código: *--."Aviso") ENDIF ENDPROC ENDDEFINE EVITAR RETORNO DE CARRO EN UN EDITBOX public oForm oForm = CREATEOBJECT("MyForm") oForm.MESSAGEBOX("No se encuentra". WITH AutoSize=. debemos poner un TextBox (Text1) y una Grilla (Grid1).Nombre >= lc IF NOT BOF() SKIP -1 ENDIF IF MiTabla. Height=200 PROCEDURE MyEditBox.Nombre < lc && debe quedar donde estaba IF lnRecno <= RECC() GO RECNO() ELSE GO BOTT ENDIF RETURN ENDIF IF NOT EMPTY(ORDER()) && busqueda con indice SEEK lc . lnRecno SELECT MiTabla lc = ALLT(THIS. WITH Top = 20. Caption="Introduzca su texto..VALUE) lnRecno = RECNO() IF MiTabla.64. Width=300. no se permite tecla ENTER" ADD OBJECT myEditBox AS EditBox .KeyPress LPARAMETERS nKeyCode. ingresando un texto en un TextBox y visualizando el resultado en un Grid En este ejemplo de BUSQUEDA INCREMENTAL en un Formulario. que todo lo podemos automatizar mediante programación desde Visual FoxPro. Simplemente hay que poner en el keypress lo siguiente: LPARAMETERS nKeyCode. o sea.Text1. debemos crear un objeto "NameSpace" apropiado que actuará como entrada (en este ejemplo MAPI). Esta interfaz está disponible como un servidor de automatización. Enviar y leer correo con Outlook desde Visual FoxPro El modelo de objetos de Outlook es muy rico y poderoso. o manejar el color del registro seleccionado LIMITAR UN CAMPO MEMO Como limitar la entrada de un campo memo a X lineas. Un breve ejemplo Una de las tareas más fácil de automatizar en Outlook es el envío de un correo.SETFOCUS && el nombre del TextBox THISFORM. pero esto no lo logramos en forma directa.Nombre=lc WHILE MiTabla.T.Grid1.ELSE GO TOP LOCATE REST FOR MiTabla.this. El objeto NameSpace proporciona entre otros.Nombre <= lc NOOPTIMIZE ENDIF IF lnRecno # RECNO() THISFORM. nShiftAltCtrl IF nkeycode = 13 IF OCCURS(chr(13). Una vez creado el objeto. . que todo lo podemos automatizar mediante programación desde Visual FoxPro.SETFOCUS && el nombre del Grid ENDIF RETURN *--.Nombre=lc WHILE MiTabla. para que se vea el registro marcado. De Ken Weber. es crear un objeto Outlook. o sea. .value) >=5 NODEFAULT ENDIF ENDIF En este ejemplo se limita a 6 lineas. LOCAL lcPerfil AS CHARACTER. El modelo de objetos de Outlook es muy rico y poderoso. lcContrasenia AS CHARACTER . debemos acceder al origen de los datos. Esta interfaz está disponible como un servidor de automatización. los métodos Logon y Logoff. Veremos un ejemplo de solamente unas pocas líneas. Lo primero que debemos hacer para automatizar Outlook.Nombre <= lc NOOPTIMIZE ENDIF ELSE LOCATE REST FOR MiTabla.END InteractiveChange --NOTA: SE DEBE TENER LAS SIGUIENTES CONSIDERACIONES: La tabla debe estar ordenada ASCENDENTEMENTE o existir un indice por Nombre y estar seleccionado (el método busca si hay un SET ORDER establecido) Fijarse bien el nombre del TextBox y del Grid para invocar el método SetFocus (en el ejemplo Grid1 y Text1) Fijarse el alias de la tabla del grid (en el ejemplo MiTabla) Conviene que los nombres estén en mayúsculas y añadir en la propiedad Format del TextBox = ! para que sean ingresados en mayúsculas Conviene que la propiedad del Grid RecordMark = . lcCuerpo AS CHARACTER LOCAL loOutlook AS "Outlook.Ejecuto los métodos loNameSpace.Application") loNameSpace = loOutlook. Cuando intentamos acceder a la libreta de direcciones aparece el cuadro de dialogo el cual nos permitirá un acceso inmediato. loNameSpace AS OBJECT. el acceso a la libreta de direcciones y el envío de correo mediante automatización. 2. Existe para descarga una versión libre con fines de desarrollo.ADD(lcDestinatario) loMailItem.dimastr. loOutlook = . entre otras cosas. . Esta DLL fue escrita por Dmitry Streblechenko (MS Outlook MVP) y esta disponible en http://www.CreateItem(0) loMailItem." + LF_CR *-. que luego de 5 segundos habilita el botón "Si". . ¿Cómo solucionamos este problema? Estas son algunas de las opciones que disponemos nosotros para trabajar con estos parches de seguridad: Mantener la versión de Office 2000 SR-1 y no actualizarla ni instalarle parches de seguridad.Logon(lcPerfil ." + LF_CR lcCuerpo = lcCuerpo + "Saludos.com/redemption.Recipients.Body = lcCuerpo loMailItem. con los peligros que esto significa. Problemas de seguridad Outlook XP y Outlook 2000 SP2.NULL. se nos presenta el siguiente cuadro de dialogo. Outlook Redemption: Es un objeto COM que se adapta fácilmente a la automatización y utiliza la MAPI extendida.Application".Logoff loNameSpace = . loMailItem AS OBJECT #DEFINE LF_CR CHR(10)+CHR(13) *-.Subject = lcTema loMailItem.com" lcTema = "Prueba: " + TTOC(DATETIME()) lcCuerpo = "Prueba enviando un mail desde Visual FoxPro. incluyen los parches de seguridad de Microsoft. lcTema AS CHARACTER . lcContrasenia) loMailItem = loOutlook. Este es un producto comercial con un valor de U$S 200 aproximadamente. con el fin de evitar códigos maliciosos que toman los datos de nuestra libreta de direcciones y envían correo sin nuestro consentimiento.lcDestinatario AS CHARACTER.Creo objetos Outlook y NameSpace loOutlook = CREATEOBJECT("Outlook. Estos parches restringen. Si se tienen Outlook y Exchange instalados. 5. el administrador de Exchange.NULL.Datos del Mail lcPerfil = "Prueba" lcContrasenia = "prueba" lcDestinatario = "[email protected]("MAPI") *-.Send loNameSpace. . puede disminuir las alertas o registrar algunas aplicaciones como seguras. o de 1. Cuando intentamos enviar un correo desde Visual FoxPro. ó 10 minutos que debemos seleccionar. txtTema.'.PARENT. 'aCC') .CargarVector(THIS.PARENT.PARENT.LeerMensajes(THIS.oCorreo .cTema = ALLTRIM(THIS.com/mailmate/clickyes. 64.Formulario de inicio de sesión DO FORM Inicio WITH THISFORM. Esta otra figura nos muestra la página para la lectura de la bandeja de entrada. En el mismo sitio existe un ejemplo para Visual FoxPro. configuramos todas las propiedades necesarias para el envío de correo. 'aTO') .VALUE = 1.txtTo.oCorreo TO llAceptar IF NOT (llAceptar AND THISFORM.VALUE. *-.Express ClickYes: Es un pequeño programa residente que se maneja mediante la API de Windows.VALUE) IF .PARENT. También en el Init() del formulario. una para enviar correo y la otra para leer los correos desde la Bandeja de Entrada. 48.VALUE.IniciarSesion()) MESSAGEBOX('Falló el inicio sesión'.CargarVector(THIS. Esto lo hacemos en el método Click() del botón "Enviar".oCorreo = NEWOBJECT('cOutlook'.VALUE.F. ZAP IN curMsg IF THISFORM.PARENT. llamamos a otro formulario para el inicio de sesión de Outlook: *-.'.VALUE) . 'curMsg') .express-soft. 'aAdjuntos') .html.txtAdjunto.oCorreo.opgTipo. En este método también creamos un objeto NameSpace que nos permitirá acceder a las carpetas especiales de Outlook. 'Problemas') ENDIF ENDWITH RETURN En el llamado del método EnviarCorreo() de la clase cOutlook es donde se crea un nuevo mensaje y se arma según las propiedades anteriormente configuradas. En el método Init() creamos una instancia de la clase cOutlook con la sentencia: THISFORM. 48.'cOutlook. ENDIF Enviar un correo Antes de invocar el método EnviarCorreo().PARENT. 'Inicio de sesión') RETURN . Este programa es gratis y esta disponible en http://www.Armo el mensaje WITH THISFORM.cCuerpo = ALLTRIM(THIS.CargarVector(THIS. La siguiente figura es la página para el envío de un correo.EnviarCorreo() MESSAGEBOX('Mensaje enviado con éxito. 'Aviso') THISFORM.prg') Creamos el servidor de automatización con: THISFORM. Este "presionará" el botón "Si" antes de que el dialogo aparezca. El formulario de ejemplo En este ejemplo utilizaremos un formulario con un objeto PageFrame con dos Páginas.LimpiarPagina() ELSE MESSAGEBOX('No se pudo enviar el mensaje. Leer los correos Para leer los correos de la bandeja de entrada invocamos el método LeerMensajes() de la clase cOutlook desde el método Click() del botón "Leer".txtCC.CrearServidor() El método CrearServidor() establece una referencia a la instancia de Outlook en la propiedad oOutlook.oCorreo.oCorreo.edtCuerpo. Application') WAIT WINDOW 'Nueva instancia de Outlook.Manejo el error con TRY . Definición de la clase cOutlook En este ejemplo disponemos de una clase definida por el usuario.' TIMEOUT 2 CATCH TO loErr1 TRY *-.PARENT.Application') WAIT WINDOW 'Ya existe una instancia de Outlook.grdMensajes.Propiedades oOutlook = .PARENT. 16. FINALLY TRY *-.. 'Aviso') ENDIF THIS.. CATH .GO TOP IN curMsg THIS.Instancio el objeto . loErr2 AS EXCEPTION.NULL.oOutlook) = 'O' .oNameSpace) = 'O' llRet = ..NULL. o solo los mensajes "No leídos" y recorremos uno a uno para cargarlos en un cursor que luego mostraremos en una Cuadrícula y un Cuadro de Edición.SETFOCUS ELSE MESSAGEBOX('No existen mensajes para traer'.oOutlook.oOutlook = GETOBJECT( .edtCuerpo.Creo el objeto .. La definición de esta clase es la siguiente: DEFINE CLASS cOutlook AS CUSTOM *-. ..T. oNameSpace = .oOutlook = CREATEOBJECT('Outlook. llRet AS Logical WITH THIS *-.GetNameSpace('MAPI') IF VARTYPE(. llamada cOutlook con los distintos métodos para realizar el envío y la lectura de los correos.. 64.'.oNameSpace = . cPerfil = '' cContrasenia = '' cTema = '' cCuerpo = '' DIMENSION aTo(1) AS CHARACTER DIMENSION aCC(1) AS CHARACTER DIMENSION aBCC(1) AS CHARACTER DIMENSION aAdjuntos(1) AS CHARACTER *-------------------------------------------------* Creo el servidor de automatización *-------------------------------------------------PROCEDURE CrearServidor() LOCAL loErr1 AS EXCEPTION.' TIMEOUT 2 CATCH TO loErr2 MESSAGEBOX('Microsoft Outlook no está instalado.. 'Outlook.REFRESH En la llamada al método LeerMensajes() creamos un objeto loInbox y traemos todos los mensajes.. 'Problemas!!!') FINALLY ENDTRY FINALLY ENDTRY IF VARTYPE(. oOutlook.cContrasenia) llRet = .Creo un nuevo mensaje WITH THIS loMensaje = .QUIT() RETURN ENDPROC *-------------------------------------------------* Iniciar sesion *-------------------------------------------------PROCEDURE IniciarSesion() LOCAL llRet AS Logical TRY THIS.Logon(THIS. lnIndex AS INTEGER *-.F.oNameSpace. llRet AS Logical LOCAL lnI AS INTEGER. FINALLY ENDTRY RETURN llRet ENDPROC *-------------------------------------------------* Cerrar sesion *-------------------------------------------------PROCEDURE CerrarSesion() THIS. THIS.ENDIF ENDIF ENDWITH RETURN llRet ENDPROC *-------------------------------------------------* Cierro el servidor de automatización *-------------------------------------------------PROCEDURE CerrarServidor() THIS.cTema loMensaje.cPerfil.aTO) FOR lnI = 1 TO lnLen .CreateItem(0) IF VARTYPE(loMensaje) = 'O' loMensaje.oOutlook.oNameSpace.cCuerpo *-.Subject = .Body = .Logoff() RETURN ENDPROC *-------------------------------------------------* Envio el correo *-------------------------------------------------PROCEDURE EnviarCorreo() LOCAL loMensaje AS OBJECT.TO lnLen = ALEN(.T.No pudo iniciar sesión llRet = .Recipientes lnIndex = 0 *-. CATCH *-. Adjuntos lnLen = ALEN(.aCC(lnI)) lnIndex = lnIndex + 1 loMensaje.aAdjuntos(lnI)) loMensaje.GetDefaultFolder(6) *-.MAPIFolder'.Recipients.Items' LOCAL loMsg AS OBJECT.aTO(lnI)) loMensaje.ADD(. tcAlias) LOCAL loInbox AS 'Outlook. loMensajes AS 'Outlook.BCC lnLen = ALEN(.SEND ELSE llRet = .aTO(lnI)) lnIndex = lnIndex + 1 loMensaje. llRet AS Logical IF EMPTY(tcAlias) tcAlias = 'curMsg' ENDIF *-.F.ADD(.aAdjuntos(lnI)) AND FILE(.Attachments.TYPE = 3 ENDIF ENDFOR *-.aCC) FOR lnI = 1 TO lnLen IF NOT EMPTY(.aBCC) FOR lnI = 1 TO lnLen IF NOT EMPTY(.Recipients(lnIndex).aBCC(lnI)) lnIndex = lnIndex + 1 loMensaje. lnI AS INTEGER.TYPE = 2 ENDIF ENDFOR *-.ADD(.aAdjuntos(lnI)) ENDIF ENDFOR llRet = loMensaje.Mensajes del Inbox .oNameSpace.aBCC(lnI)) loMensaje.CC lnLen = ALEN(.TYPE = 1 ENDIF ENDFOR *-.IF NOT EMPTY(. ENDIF ENDWITH RETURN llRet ENDPROC *-------------------------------------------------* Lee los mensajes según parámetro *-------------------------------------------------PROCEDURE LeerMensajes(tlNoLeidos.Recipients(lnIndex).Inbox loInbox = THIS.ADD(.aAdjuntos) FOR lnI = 1 TO lnLen IF NOT EMPTY(.Recipients(lnIndex).Recipients.Recipients.aCC(lnI)) loMensaje. '.'. Cuerpo. tcTexto. . Tema. . ENDIF RETURN llRet ENDPROC *-------------------------------------------------* Destroy *-------------------------------------------------PROCEDURE DESTROY() WITH THIS .NULL.Items ENDIF IF VARTYPE(loMensajes) = 'O' WITH loMensajes IF . .ITEM(lnI) WITH loMsg INSERT INTO (tcAlias) (EnviadoPor. . tcVector) LOCAL ln AS INTEGER. lnI AS INTEGER.IF tlNoLeidos loMensajes = loInbox.Body.UnRead) ENDWITH ENDFOR llRet = .') ln = ALINES(la. NoLeido) ." + tcVector DIMENSION &lcV.oOutlook = .F. . ENDIF ENDWITH ELSE llRet = . la(1) AS CHARACTER IF EMPTY(tcTexto) RETURN 0 ENDIF tcTexto = CHRTRAN(tcTexto.'. VALUES (.(lnI) = la(lnI) ENDFOR RETURN ln .RESTRICT("[Unread] = True") ELSE loMensajes = loInbox.T.Items. '.. Recibido.oNameSpace = .NULL.Recorro los mensajes FOR lnI = 1 TO .SenderName.T.ReceivedTime.(ln) FOR lnI = 1 TO ln &lcV. ELSE llRet = .') lcV = "This.Subject.COUNT > 0 *-.COUNT loMsg = .F. . ENDWITH ENDPROC *-------------------------------------------------* Cargo una Matriz con los destinatarios *-------------------------------------------------PROCEDURE CargarVector(tcTexto. WIDTH = 780.WIDTH = THIS.INIT THIS.HEIGHT . .2" PROCEDURE RESIZE THIS. Una forma fácil de crear un formulario por código como un explorador de internet. en esta ocasión.olecontrol1.T. El único detalle es el parpadeo cuando se lanza . .portalfox. como así también los formularios.olecontrol1.com") loBrowser. CAPTION = "PortalFox :: Nada corre como un zorro" WINDOWSTATE = 0 NAME = "Form1" WIDTH = 800 HEIGHT = 600 ADD OBJECT olecontrol1 AS OLECONTROL WITH .Explorer... . HEIGHT = 580.HOME()+"gallery\_webview") loBrowser.Navigate2("http://www. PUBLIC oForm oForm = NEWOBJECT("MiExplorador") oForm. .20 ENDPROC PROCEDURE olecontrol1.. Los ejemplos están realizados con Visual FoxPro 8 y Outlook 2002 (Outlook XP).con este cambio aun cuando haya campos memos y estos excedan su longitud (la pagina actual). cómo mostrar una pagina Web en un formulario de Visual FoxPro.olewebBROWSER.NAVIGATE("http://www. me sale la numeración correctamente. . y el ejemplo los podemos descargar del siguiente vínculo: outlook.20 THIS. lo único que modifique es el NOCONSOLE por el NOWAIT.HEIGHT = THIS. . TOP = 10.portalfox.Show(1) NUMERACION DE PAGINAS EN INFORMES CON CAMPOS MEMO En la función de Rafael Angel Ponce Yllanes se tiene el detalle de los campos Memo.zip para su evaluación. Pueden revisar las Fox Foundation Classes (FFCs) para saber cómo funciona: Utilities -> Component Gallery -> Internet -> Web Broser Control Un ejemplo sencillo sobre esto: loBrowser=NEWOBJECT("_webform". OLECLASS = "Shell..SHOW DEFINE CLASS MiExplorador AS FORM TOP = 0 LEFT = 0 DOCREATE = .WIDTH . LEFT = 10.com") ENDPROC ENDDEFINE MOSTRAR UNA PAGINA WEB DESDE TU PROGRAMA DE VFP Una mas sobre las Fox Foundation Classes.ENDPROC ENDDEFINE && Clase cOutlook A la definición de la clase. . NAME = "Olecontrol1".REFRESH NODEFAULT ENDPROC PROCEDURE olecontrol1. "Editando Archivo".. * Notas: * Creación : 08/09/1999 PRR * Ultima Modificación: 14/04/2000 RAPY Rafael Angel Ponce Yllanes * Ultima Modificación: 28/07/2004 LINCEITZ Pablo Alvarez G.cmdClose. && Path del archivo a Mostrar tcCaption.el report por primera vez. Normal = 0.cmdSave..Caption="Fuentes" .Caption="Cerrar" . Minimizado = 1 ."Visor de Texto") . Título de la Venta tnWindowState && Estado de la ventana.vcx. en esta ocasión haremos una SubClase basada en _ShowText de la librería de clases _Reports.cmdFonts..vcx") PROCEDURE INIT LPARAMETERS tcSourceFile.SHow(1) DEFINE CLASS myTextEditor as _showtext OF (HOME(1)+"ffc\_reports. te damos la manera mas sencilla y con apariencia bastante profesional.0) .Caption="Sólo lectura" ENDWITH ENDPROC .2) oForm.tcCaption.Caption = IIF(VARTYPE(tcCaption)='C' AND !EMPTY(tcCaption).chkReadOnly. Maximizado =2 DODEFAULT(tcSourceFile) WITH This . para de ésta manera hacerlo mas beneficioso a nuestro propósito..0.Caption="Guardar como" . oForm=CREATEOBJECT("MyTextEditor".tnWindowState.1 TO 2.2 ACTIVATE WINDOW x NOSHOW REPORT FORM (lc_report) NOWAIT nPaginas = _PAGENO RELEASE WINDOW x RETURN npaginas ENDFUNC ************************************************************ IMPLEMENTAR UN VISOR DE TEXTO Si deseas mostrar un buen visor de textos que puedes implementar en tus aplicaciones. Una vez más utilizaremos una clase de las que vienen en las Fox Foundation Classes (FFCs) de Visual FoxPro. ************************************************************ FUNCTION report_contarpaginas(lc_report) LOCAL nPaginas nPaginas = 0 DEFINE WINDOW x FROM 1.2).1.WindowState=IIF(VARTYPE(tnWindowState)='N' AND INLIST(tnWindowState. ************************************************************ * Función: report_contarpaginas * Devuelve el número de paginas de un report * Parametros: * Nombre del report * Ejemplos: * lntotpaginas = report_contapaginas("minforme") * Retorno: * El numero de paginas del informe. pero prefiero esto a una numeración incorrecta.GETFILE(). lo único que solo funciona de la versión 6. podrías utilizar tu propio método para generar un reporte o mandar tu reporte a ASCII (REPORT FORM < TuReporte > TO FILE ASCII ) . pasarlo a archivo y mostrarlo..lcFile.2) oForm. Esta línea de código me pareció muy buena.Resize() DODEFAULT() ENDPROC ENDDEFINE Como idea adicional. menor-que < < > > de la sección TEXTMERGE.PROCEDURE Activate This..dbc" SET TEXTMERGE ON SET TEXTMERGE TO (lcFile) NOSHOW lcTitle="Reporte de Clientes" IF !USED("Customer") USE Customer IN 0 ENDIF SELECT Customer \< < PADC(lcTitle. PREVIEW EN FORMA MAXIMIZADA Y CON DIALOGO DE IMPRESIÓN Preview en forma maximizada y con diálogo de impresión.lcTitle. con él se pueden configurar mas opciones de la clase.Show(1) DELETE FILE (lcFile) CLOSE TABLES all CLOSE DATABASES all Nota: Por cuestiones de codificacion HTML tuve que poner espacios entre los mayor-que.40. lcFile = SYS(2015)+".h que se localiza en el mismo directorio de la librería de clases..80. Nota2: Revise el archivo _reports...txt" OPEN DATABASE HOME(2)+"data\testdata...0 en adelante." ") > > \Clave < < PADC("Compañia".. quitelos para que funcione correctamente. mucho más fácil y en una sola línea.. Esto antes de lanzar el REPORT PREVIEW KEYBOARD "{CTRL+F10}" Conocer el número de paginas totales de un informe ************************************************************ * . KEYBOARD '{CTRL+F10}' PLAIN CLEAR REPORT FORM tureporte NOCO TO PRINTER PROMPT PREV INFORME CON VISTA PREVIA MAXIMIZADA Solo hay que hacer ." ") > > Contacto SCAN \< < Cust_id > > < < Company > > < < Contact > > ENDSCAN SET TEXTMERGE TO SET TEXTMERGE OFF oForm=CREATEOBJECT("MyTextEditor". 1') ? loSock. si se utiliza la propiedad STRETCH WITH OVERFLOW suelen ocurrir resultados inesperados Obtener la dirección IP local de la maquina. COMPRIMIR ARCHIVOS CON WINRAR Has deseado tener un programa en donde este archivado todas las rutas de carpetas a comprimir y con especificaciones de tipos de archivos y una ruta de almacenamiento.* Clase: report_contarpaginas * * Devuelve el número de paginas de un report * * Parametros: * * Nombre del report * * Ejemplos: * * lntotpaginas = report_contapaginas("minforme") * * Retorno * * El numero de paginas del informe. con esto se mejora mucho la velocidad. en donde se almacenaran tus respaldos *** ejemplo: resplado. *** crea un tabla que contenga la ruta de almacenamiento. con el campo "Almacena" y guardar "e:\backup" *** crea .LocalIP loSock = .2 ACTIVATE WINDOW x NOSHOW REPORT FORM (lc_report) NOCONSOLE nPaginas = _PAGENO RELEASE WINDOW x RETURN npaginas NOTA: gracias a Jose Luis Santana Blasco y a Rafael Angel Ponce Yllanes por la aclaración del NOCONSOLE.1 TO 2. * * Nota * * * Creación : 08/09/1999 PRR * Ultima Modificación: 14/04/2000 RAPY Rafael Angel Ponce Yllanes * ************************************************************ PARAMETERS lc_report LOCAL nPaginas nPaginas = 0 DEFINE WINDOW x FROM 1.dbf.NULL. Nota: Se ha reportado que con Campos MEMO. y solo dar un click para iniciar el proceso de respaldo. loSock = CREATEOBJECT('MSWinsock.Winsock. 8)+'_'+RIGHT(DTOS(DATE()).05.dbf *.6) GO TOP *** INICIO DE LA GENERACION DE ARCHIVOS RAR SCAN ALL ZRUTA=ALLTRIM(RUTA)+'\'+ALLTRIM(EXTENSION) ZSAV=ALLTRIM(wAlmacena)+'\'+ALLTRIM(NOMBRE)+'. $145. al poner multiples extensiones solo separarlas con espacio *** inicio *** USE Respaldo wAlmacena=RESPALDO.nvalor * 20) / 20 endfunc INSERTAR REGISTRO EN UNA POSICION Cuantas veces no hemos querido ingresar un registro en blanco en alguna posicion especifica de una tabla ? Esta es una manera muy simple de hacerlo: GO 3 INSERT BLANK BEFORE Te aconsejo no intentar este tipo de manejos sobre tablas medianas o grandes.una tabla que tenga los nombre y rutas de las carpetas a respaldar y un campo que *** guarde las extensiones. . ya que es muy lento y además necesitas abrir la tabla en forma exclusiva.doc *.nValor return ceiling(m.ppt" o bien "*.07 se convierte en $145.ALMACENA USE DIRECTORIO *** GENERA LOS NOMBRES DE LOS RESPALDOS AUTOMATICAMENTE *** Y LE AGREGA FECHA PARA NO SOBRE ESCRIBIRLOS REPLACE ALL NOMBRE WITH +RIGHT(SYS(2015).xls *.RAR'+' '+ZRUTA ! /N7 RAR a -r -s &ZSAV ENDSCAN *** REDONDEAR A 5 CENTAVOS POR ARRIBA Esta función es muy útil para establecimientos donde las monedas de centavos ya no se usan tan frecuentemente y/o por comodidad se cobra 5 centavos arriba.*".10.02 se convierte en $145. es decir: $145.dbf con el campos: ruta y extension ambos de tipo caracter *** Ejemplo : ruta = "c:\mis documentos\" *** Ejemplo : extension = "*. function redondeoacincocentimos lparameters m. puedes agregar multiples registros de carpetas a respaldar *** Ejemplo : directorio.
Copyright © 2024 DOKUMEN.SITE Inc.