Top Banner
APEX & Christian Rokitta OGh APEX World 9 April 2013 APEX World 2013
31

APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

May 01, 2018

Download

Documents

truongquynh
Welcome message from author
This document is posted to help you gain knowledge. Please leave a comment to let me know what you think about it! Share it to your friends and learn new things together.
Transcript
Page 1: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

APEX &

Christian Rokitta OGh APEX World

9 April 2013

APEX World 2013

Page 2: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

75 APEX sessions in 4 days +

Symposium day with Oracle Dev Team kscope13.com

Samenwerkingsverband van

zelfstandige APEX professionals smart4apex.nl

Page 3: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

• PhoneGap: Concept en Architectuur

• APEX & PhoneGap

• PhoneGap API (met APEX)

• Cross Platform App Development

Page 4: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl
Page 5: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

SQL & PL/SQL

Page 6: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl
Page 7: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl
Page 8: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl
Page 9: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

Easily create apps using the web technologies you know and love: HTML, CSS, and JavaScript

PhoneGap is a free and open source framework that allows you to create

mobile apps using standardized web APIs

Page 10: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

Native OS

PhoneGap Container App

WebView

Java

Scri

pt

AP

I

Nat

ive

AP

I

<HTML />

{CSS;}

Javascript();

images.png

Page 11: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

• Eclipse

• Android SDK

• Android Development Tools (ADT) Plugin voor Eclipse IDE

• Apache Cordova (PhoneGap)

http://www.phonegap.com

Page 12: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

• Project

New Eclipse Project

PhoneGap libs/js/xml kopiëren

Configuratie: java/xml/html bestanden

• Deploy Simulator/Smartphone

Page 13: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

Hoe krijgen wij APEX in de

PhoneGap WebView Container?

Page 14: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

A. APEX URL ipv index.html aanroepen in MainActivity.java: super.loadUrl("http://apex.oracle.com/pls/apex/f?p=41097:1");

B. PhoneGap libraries in APEX pagina’s opnemen

Page 15: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

• Domain Whitelisting is een security model om toegang tot servers buiten de WebView Containers te controleren.

• Standaard worden alle aanroepen in het net geblokkeerd.

• De ontwikkelaar kan toegang tot (sub-) domeinen declareren.

Page 16: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

• <access> element, W3C specificatie: <access origin="http://example.com" />

<access origin="https://example.com" subdomains="true" />

• Platform afhankelijk

– Android: res/xml/cordova.xml, volledige ondersteuning syntax

– Windows: default alle domeinen toegankelijk

– iOS: geen ondersteuning protocollen, * syntax flexibeler

Page 17: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl
Page 18: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

Definitie JS functie: navigator.camera.getPicture( cameraSuccess

, cameraError

[ , cameraOptions ] );

cameraSucces/Error: functions

Page 19: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

cameraOptions:

{ quality : 75, destinationType : Camera.DestinationType.DATA_URL, sourceType : Camera.PictureSourceType.CAMERA, allowEdit : true, encodingType: Camera.EncodingType.JPEG, targetWidth: 100, targetHeight: 100, popoverOptions: CameraPopoverOptions, saveToPhotoAlbum: false };

Camera.DestinationType = { DATA_URL : 0, // Return image as base64 encoded string FILE_URI : 1 // Return image file URI };

Page 20: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

document.addEventListener("deviceready", onDeviceReady, onFail);

// Cordova is ready to be used!

//

function onDeviceReady() {

pictureSource = navigator.camera.PictureSourceType;

destinationType = navigator.camera.DestinationType;

console.log('Device ready!');

}

Page 21: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

// A button will call this function

//

function capturePhoto() {

// Take picture using device camera

// and retrieve image as base64-encoded string

navigator.camera.getPicture(

onPhotoDataSuccess

, onFail

, {quality: 50

,destinationType: destinationType.DATA_URL}

);

}

Page 22: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

function onPhotoDataSuccess(imageData) {

// Unhide image element

$("#smallImage").css("display", "block");

// Show the captured photo

$("#smallImage").attr(

"src"

, "data:image/jpg;base64," + imageData);

// Copy image data

staticImg = imageData;

}

Page 23: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

// Function to upload CLOB data using APEX AJAX API

function clob_set() {

var clob_ob = new apex.ajax.clob(

function() {

var rs = p.readyState

if (rs == 1 || rs == 2 || rs == 3) {

$.mobile.showPageLoadingMsg();

} else if (rs == 4) {

$s('P1_RESPONSE', p.responseText);

$.mobile.hidePageLoadingMsg()

} else {

return false;

}

});

clob_ob._set(staticImg);

}

http://carlback.blogspot.nl/2008/04/new-stuff-4-over-head-with-clob.html

Page 24: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

DECLARE l_clob CLOB; l_blob BLOB; l_id NUMBER; BEGIN -- fetch the image CLOB from the collection SELECT clob001 INTO l_clob FROM apex_collections WHERE collection_name = 'CLOB_CONTENT'; l_id := blob_test_seq.NEXTVAL; -- convert base64 CLOB into BLOB image l_blob := apex_web_service.clobbase642blob(l_clob); INSERT INTO blob_test(id, blob_content, mime_type, file_name) VALUES (l_id, l_blob, 'image/jpeg', 'image' || l_id || '.jpg'); END;

http://carlback.blogspot.nl/2008/04/new-stuff-4-over-head-with-clob.html

Page 25: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl
Page 26: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl
Page 27: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl
Page 28: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

<!DOCTYPE html>

<html>

<head>

<title>Redirect</title>

</head>

<body onload="window.location.href='http://apex.oracle.com/pls/apex/f?p=demo';">

</body>

</html>

Page 29: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

<script>

(function loadCordova() {

//Initialize our user agent string to lower case.

var uagent = navigator.userAgent.toLowerCase();

if (uagent.search("android") > -1) {

document.write('<script type="text/javascript" ' +

'src="#WORKSPACE_IMAGES#cordova.android.js">' +

'<//script>');

} else if (uagent.search("iphone") > -1) {

document.write('<script type="text/javascript" ' +

'src="#WORKSPACE_IMAGES#cordova.ios.js">' +

'<//script>');

}

})();

</script>

Page 30: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl

[email protected]

themes4apex.nl

rokitta.blogspot.com

@crokitta

Page 31: APEX - nlOUG · 75 APEX sessions in 4 days + Symposium day with Oracle Dev Team kscope13.com Samenwerkingsverband van zelfstandige APEX professionals smart4apex.nl