Árvore de páginas

Versões comparadas

Chave

  • Esta linha foi adicionada.
  • Esta linha foi removida.
  • A formatação mudou.

...

Portuguese

Este arquivo HTML contém o exemplo das chamadas e callBacks das funções para acesso aos perifericos dos dispositivo (camera, gps, etc) e também para acesso ao banco da dados SQLite.

Arquivo

Bloco de código
languagehtml
themeEclipse
linenumberstrue
collapsefalse
<!DOCTYPE html>
<html>

<head>
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">

    <style>
        body {
            font-family: 'Calibri';
        }
        
        a {
            text-decoration: none;
        }
        
        div {
            display: inline-block;
            float: left;
            background-color: #019AC4;
            color: #FFFFFF;
            width: 250px;
            height: 34px;
            margin: 10px;
            padding: 10px;
        }
    </style>

    <script src="totvstec.js"></script>
    <script>
        onload = function () { loadEngine(); }

        function loadEngine() {

            // Conecta WebSocket Server
            totvstec.connectWS( function(){
                // Carrega mensageria exclusiva da pagina
                dialog.advplToJs.connect(function (codeType, codeContent, objectName) {
                    //if (codeType == "") {
                    //}
                });

                // Envia sinal informando termino da carga
                dialog.jsToAdvpl("page_started", "Pagina inicializada");
            });
            
        }

        // Funcoes de CallBack Advpl -> JS
        function getPictureSuccess(image) {
            totvstec.createNotification( 1, "getPicture", image );
            totvstec.runAdvpl('Encode64(,"' + image + '",.T.,.T.)', imgEncodedSuccess);
        }

        function barCodeScannerSuccess(barCode) {
            totvstec.createNotification( 1, "barCodeScanner", barCode );
        }

        function pairedDevicesSuccess(paired) {
            alert(paired);
        }

        function getCurrentPositionSuccess(position) {
        	// Necessario retirar o sinal de Grau para que o MAPS reconheca a posicao
    window.location.href = "http://maps.google.com/?q=" + position;
        }
        
       position =function position.replace(/?/g, "");readAccelerometerSuccess(sensorRead) {
            window.location.href = "http://maps.google.com/?q=" + positionalert(sensorRead);
        }
        
        function readAccelerometerSuccessaddCalendarSuccess(sensorReadid) {
            alert(sensorRead"CalendarId:" + id);
        }
        
        function addCalendarSuccess(id) {
            alert("CalendarId:" + id);
        }
        
        var savedid = "var savedid = "0";
        function findCalendarSuccess(retIds) {
            alert("Ids encontrados " + retIds);
            obj = JSON.parse(retIds);
            savedid = obj.ids[0];
        }
        
        function getCalendarSuccess(calev) {
            obj = JSON.parse(calev);
            alert("titulo    - " + obj.title      + "\n" +
                  "descricao - " + obj.descr      + "\n" +
                  "local     - " + obj.addr       + "\n" +
                  "data ini  - " + obj.startdate  + "\n" +
                  "hora ini  - " + obj.starttime  + "\n" +
                  "data fim  - " + obj.enddate    + "\n" +
                  "hora fim  - " + obj.endtime    + "\n" +
                  "dia todo  - " + obj.allday);
        }
        		
		function getDate(){
			var today = new Date();
			var dd = today.getDate();
			var mm = today.getMonth()+1; //January is 0!
			var yyyy = today.getFullYear();
			return mm+'/'+dd+'/'+yyyy;
		}
		
		function runAdvplSuccess(retStr){
			alert(retStr);
		}

        		
		function testDeviceSuccessimgEncodedSuccess(lRetretStr){
		      //Envia a imagem encoded em  alert(lRet);
base64 via REST/JSON/XML
		      //Para exemplificar, }
quem receber isto deve fazer parecido com  abaixo
		        function getTempPathSuccess(tempPath){
        	alert(tempPath)
        }

		function dbGetSuccess(data){
			var jsonStr = JSON.stringify(data);
			alert('dbGetSuccess: ' + jsonStr.replace(/"/g, "'"));
		}
		
		function dbError(error){
			alert("dbError: " + error);
		}
		function dbSuccess(){
			// Dummy
		}
		
		// Cria tabela
		function dbCreateTableSuccess(){
			totvstec.dbExec( "insert into newTab values (1,'User 1')", dbSuccess, dbError );
			totvstec.dbExec( "insert into newTab values (2,'User 2')", dbSuccess, dbError );
			totvstec.dbExec( "insert into newTab values (3,'User 3')", dbSuccess, dbError );
			alert("dbCreateTableSuccess: Tabela criada com sucesso");
		}totvstec.decode64(retStr,"imagem.jpg",true, imgSavedSuccess);
		}
		function imgSavedSuccess(ret){
			alert("Imagem " + ret + " salva com sucesso!");
		}

        function testDeviceSuccess(lRet){
            alert(lRet);
        }
        
        function getTempPathSuccess(tempPath){
        	alert(tempPath);
        }
		
		function findContactSuccess(contact) {
			alert(contact);
		}

		function dbGetSuccess(data){
			var jsonStr = JSON.stringify(data);
			alert('dbGetSuccess: ' + jsonStr.replace(/"/g, "'"));
		}
		
		function dbError(error){
			alert("dbError: " + error);
		}
		function dbSuccess(){
			// Dummy
		}
		
		function dbCreateTablegetFindContactFilter(){
			totvstec.dbExec("create table newTab (cod INTEGER, name TEXT)", dbCreateTableSuccess, dbErrorvar filter = prompt("Entre com a palavra-chave: ", "TOTVS");
		}
		
		// Deleta tabela
		function dbDropTableSuccess()	if (filter != null) {
			alert("dbDropTable: Ok")	return filter;
			}
		function	else dbDropTable(){
				totvstec.dbExec("drop table newTab", dbDropTableSuccess, dbError)return "";
			}
		}
		
		// Cria tabela
		function testCommitProcessdbCreateTableSuccess(){
			totvstec.dbBegindbExec(dbSuccess, dbError);
			totvstec.dbExec( "insert into newTab values (41,'User 41')", dbSuccess, dbError );
			totvstec.dbExec( "insert into newTab values (52,'User 52')", dbSuccess, dbError );
			totvstec.dbExec( "insert into newTab values (63,'User 63')", dbSuccess, dbError );
			totvstec.dbCommit(dbSuccess, dbError);
			alert("testCommitProcessdbCreateTableSuccess: Ok Tabela criada com sucesso");
		}		

		function testRollbackProcessdbCreateTable(){
			totvstec.dbBegin(dbSuccessdbExec("create table newTab (cod INTEGER, name TEXT)", dbCreateTableSuccess, dbError);
			totvstec.dbExec( "insert into newTab values (4,'User 4')", dbSuccess, dbError );}
		
		// Deleta tabela
		function dbDropTableSuccess(){
			alert("dbDropTable: Ok");
		}
		function dbDropTable(){
			totvstec.dbExec( "insertdrop intotable newTab values (5,'User 5')", dbSuccessdbDropTableSuccess, dbError );
				totvstec}

		function testCommitProcess(){
			totvstec.dbBegin(dbSuccess, dbError);
			totvstec.dbExec( "insert into newTab values (64,'User 64')", dbSuccess, dbError );
			totvstec.dbRollback(dbExec( "insert into newTab values (5,'User 5')", dbSuccess, dbError );
			alerttotvstec.dbExec("testRollbackProcess: Ok" "insert into newTab values (6,'User 6')", dbSuccess, dbError );
			totvstec.dbCommit(dbSuccess, dbError);
			alert("testCommitProcess: Ok");
		}
		


		function testRollbackProcess(){
			totvstec.dbBegin(dbSuccess, dbError);
			totvstec.dbExec( "insert into newTab values (4,'User 4')", dbSuccess, dbError );
			totvstec.dbExec( "insert into newTab values (5,'User 5')", dbSuccess, dbError );
			totvstec.dbExec( "insert into newTab values (6,'User 6')", dbSuccess, dbError );
			totvstec.dbRollback(dbSuccess, dbError);
			alert("testRollbackProcess: Ok");
		}
		
    </script>
</head>

<body>
    <font face=calibri color="#FFFFFF">

        <p><img src="logo_totvs.png" align="left">
            <br>
            <font size=14 face=calibri color="#039CBB">&nbsp;Cloud Bridge - Custom</font>
        </p><br>

        <div style="background-color: #DB4437; width: 90%; height: 12px;">
            <font size="4">Acesso ao SQLite </font><br><br>
        </div>

        <a onclick='dbCreateTable();'>
            <div>
                <font size="5">Cria Tabela</font><br><br>
            </script>
</head>

<body>
div>
      <font face=calibri color="#FFFFFF"> </a>

        <p><img<a src="logo_totvs.png" align="left"onclick='dbDropTable();'>
            <br><div>
                <font size=14 face=calibri color="#039CBB">&nbsp;Cloud Bridge - Custom</font>"5">Apaga Tabela</font><br><br>
            </div>
        </p><br>a>

        <div<a styleonclick="background-color: #DB4437; width: 90%; height: 12px;">
'totvstec.dbGet("select * from newTab", dbGetSuccess, dbError);'>
            <div>
                <font size="4">Acesso ao SQLite5">Recupera dados</font><br><br>
            </font><br><br>div>
        </div>
a>
        
        <a onclick='dbCreateTable(totvstec.dbGet("SELECT name FROM sqlite_master WHERE type=\"table\"", dbGetSuccess, dbError);'>
            <div>
                <font size="5">Cria>Lista Tabela<Tabelas</font><br><br>
            </div>
        </a>        

        <a onclick='dbDropTabletestRollbackProcess();'>
            <div>
                <font size="5">Apaga Tabela<>Proc.c/ Rollback</font><br><br>
            </div>
        </a>

        <a onclick='totvstec.dbGet("select * from newTab", dbGetSuccess, dbError onclick='testCommitProcess();'>
            <div>
                <font size="5">Recupera dados<>Proc. c/ Commit</font><br><br>
            </div>
        </a>
        
        <a<div onclickstyle='totvstec.dbGet("SELECT name FROM sqlite_master WHERE type=\"table\"", dbGetSuccess, dbError);'>
            <div>
   "background-color: #DB4437; width: 90%; height: 12px;">
             <font size="54">Lista>Acesso ao Tabelas<periferico</font><br><br>
            </div>
        </a>        

        <a onclick='testRollbackProcess(totvstec.runAdvpl("DtoS(CtoD(\"" +getDate()+ "\"))", runAdvplSuccess);'>
            <div>
                <font size="5">Proc.c/ Rollback</>runAdvpl</font><br><br>
            </div>
        </a>

        <a onclick='testCommitProcess(totvstec.getPicture(0,getPictureSuccess);'>
            <div>
                <font size="5">Proc. c/ Commit<>Captura imagem</font><br><br>
            </div>
        </a>
        
        <div<a style="background-color: #DB4437; width: 90%; height: 12px;">onclick='totvstec.getPicture(200,getPictureSuccess);'>
            <div>
                <font size="4">Acesso ao periferico</font><br><br>5">Captura imagem (Redimensionando)</font><br><br>
            </div>
        </div>a>

        <a onclick='totvstec.runAdvpl("DtoS(CtoD(\"" +getDate()+ "\"))", runAdvplSuccess)barCodeScanner(barCodeScannerSuccess);'>
            <div>
                <font size="5">runAdvpl<>C&oacute;digo de barras</font><br><br>
            </div>
        </a>

        <a onclick='totvstec.getPicturepairedDevices(0,getPictureSuccesspairedDevicesSuccess);'>
            <div>
                <font size="5">Captura imagem<>Pareados</font><br><br>
            </div>
        </a>
        
        <a onclick='totvstec.getPicturegetCurrentPosition(200,getPictureSuccessgetCurrentPositionSuccess);'>
            <div>
                <font size="5">Captura imagem (Redimensionando)<>Geo Posi&ccedil;&atilde;o</font><br><br>
            </div>
        </a>

        <a onclick='totvstec.barCodeScannerunlockOrientation(barCodeScannerSuccess);'>
            <div>
                <font size="5">C&oacute;digo de barras<>Libera Orienta&ccedil;&atilde;o</font><br><br>
            </div>
        </a>

        <a onclick='totvstec.pairedDeviceslockOrientation(pairedDevicesSuccess);'>
            <div>
                <font size="5">Pareados<>Trava Orienta&ccedil;&atilde;o</font><br><br>
            </div>
        </a>

        <a onclick='totvstec.getCurrentPosition(getCurrentPositionSuccesscreateNotification( 1, "Titulo da Notifica&ccedil;&atilde;o", "Corpo  da Notifica&ccedil;&atilde;o" );'>
            <div>
                <font size="5">Geo Posi>Notifica&ccedil;&atilde;o</font><br><br>
            </div>
        </a>

        <a onclick='totvstec.unlockOrientationvibrate(400);'>
            <div>
                <font size="5">Libera Orienta&ccedil;&atilde;o<5">Vibrar</font><br><br>
            </div>
        </a>

        <a onclick='totvstec.lockOrientationgetTempPath(getTempPathSuccess);'>
            <div>
                <font size="5">Trava Orienta&ccedil;&atilde;o<>GetTempPath</font><br><br>
            </div>
        </a>
        
        <a onclick='totvstec.createNotification( 1, "Titulo da Notifica&ccedil;&atilde;o", "Corpo  da Notifica&ccedil;&atilde;o" readAccelerometer(readAccelerometerSuccess);'>
            <div>
                <font size="5">Notifica>Aceler&ccedil;&atilde;o<ocirc;metro</font><br><br>
            </div>
        </a>


        
        <a onclick='totvstec.vibrateenblOnPause(400);'>
            <div>
                <font size="5">Vibrar<>Ativar OnPause</font><br><br>
            </div>
        </a>
        
        <a onclick='totvstec.getTempPathenblOnResume(getTempPathSuccess);'>
            <div>
                <font size="5">GetTempPath<>Ativar OnResume</font><br><br>
            </div>
        </a>
        
        <a onclick='totvstec.readAccelerometer(readAccelerometerSuccess);'>
            <div>
                <font size="5">Aceler&ocirc;metro</font><br><br>
            </div>addContact("CST TOTVS", "Centro de Servi&ccedil;os TOTVS", "TOTVS SA", "[email protected]", 2, "+55 11 4003-0015", 2, "Av. Braz Leme, 1631 - Jd. S&atilde;o Bento - S&atilde;o Paulo/SP", "Canal exclusivo para assuntos administrativos e financeiros. Atendimento: de segunda &agrave; sexta, das 8h00 &agrave;s 12h00 e das 13h30 &agrave;s 18h00.");'>
        </a>

    <div>
    <a onclick='totvstec.addContact( "CST TOTVS", "Centro de Servi&ccedil;os TOTVS", "TOTVS SA", "[email protected]", 2, "+55 11 4003-0015", 2, "Av. Braz Leme, 1631 - Jd. S&atilde;o Bento - S&atilde;o Paulo/SP", "Canal exclusivo para assuntos administrativos e financeiros. Atendimento: de segunda &agrave; sexta, das 8h00 &agrave;s 12h00 e das 13h30 &agrave;s 18h00." <font size="5">AddContact</font><br><br>
            </div>
        </a>
		
        <a onclick='totvstec.findContact(getFindContactFilter() , findContactSuccess);'>
            <div>
                <font size="5">AddContact<>FindContact</font><br><br>
            </div>
        </a>
        
        <a onclick='totvstec.addCalendar("TOTVS", "Descrição TOTVS", "Endereço TOTVS", new Date().toJSON().slice(0,10),"08:00:00", new Date().toJSON().slice(0,10), "09:00:00", "False", addCalendarSuccess);'>
            <div>
                <font size="5">AddCalendar</font><br><br>
            </div>
        </a>
        
        <a onclick='totvstec.findCalendar(new Date().toJSON().slice(0,10),new Date( (new Date()).valueOf() + 1000*3600*24 ).toJSON().slice(0,10), findCalendarSuccess);'>
            <div>
                <font size="5">FindCalendar</font><br><br>
            </div>
        </a>
        
        <a onclick='totvstec.viewCalendar(savedid);'>
            <div>
                <font size="5">ViewCalendar</font><br><br>
            </div>
        </a>
        
        <a onclick='totvstec.getCalendar(savedid,getCalendarSuccess);'>
            <div>
                <font size="5">GetCalendar</font><br><br>
            </div>
        </a>
        
        <a onclick='alert(totvstec.version);'>
            <div>
                <font size="5">Vers&atilde;o JS</font><br><br>
            </div>
        </a>

        <div style="background-color: #DB4437; width: 90%; height: 12px;">
            <font size="4">Testa os perifericos</font><br><br>
        </div>

        <a onclick='totvstec.testDevice(totvstec.BLUETOOTH_FEATURE, testDeviceSuccess)'>
            <div>
                <font size="5">Testa BlueTooth</font><br><br>
            </div>
        </a>
        <a onclick='totvstec.testDevice(totvstec.NFC_FEATURE, testDeviceSuccess)'>
            <div>
                <font size="5">Testa NFC</font><br><br>
            </div>
        </a>
        <a onclick='totvstec.testDevice(totvstec.WIFI_FEATURE, testDeviceSuccess)'>
            <div>
                <font size="5">Testa WIFI</font><br><br>
            </div>
        </a>
        <a onclick='totvstec.testDevice(totvstec.LOCATION_FEATURE, testDeviceSuccess)'>
            <div>
                <font size="5">Testa GPS</font><br><br>
            </div>
        </a>
        
        <a onclick='totvstec.testDevice(totvstec.CONNECTED_WIFI, testDeviceSuccess)'>
            <div>
                <font size="5">Conectado WIFI</font><br><br>
            </div>
        </a>
        <a onclick='totvstec.testDevice(totvstec.CONNECTED_MOBILE, testDeviceSuccess)'>
            <div>
                <font size="5">Conectado 3G</font><br><br>
            </div>
        </a>

        <div style="background-color: #DB4437; width: 90%; height: 12px;">
            <font size="4">Abre as configura&ccedil;&otilde;es</font><br><br>
        </div>

        <a onclick='totvstec.openSettings(totvstec.BLUETOOTH_FEATURE)'>
            <div>
                <font size="5">Abre BlueTooth</font><br><br>
            </div>
        </a>
        <a onclick='totvstec.openSettings(totvstec.NFC_FEATURE)'>
            <div>
                <font size="5">Abre NFC</font><br><br>
            </div>
        </a>
        <a onclick='totvstec.openSettings(totvstec.WIFI_FEATURE)'>
            <div>
                <font size="5">Abre WIFI</font><br><br>
            </div>
        </a>
        <a onclick='totvstec.openSettings(totvstec.LOCATION_FEATURE)'>
            <div>
                <font size="5">Abre GPS</font><br><br>
            </div>
        </a>

</body>

</html>