87
Cross Platform 지원을 위한 소프트웨어 개발 방안 김영욱 Evangelist 개발자 및 플랫폼 사업총괄 / 부장 [email protected]

20141216 멜팅팟 부산 세션 ii - cross platform 개발

Embed Size (px)

Citation preview

Page 1: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Cross Platform 지원을 위한소프트웨어 개발 방안

김영욱 Evangelist개발자 및 플랫폼 사업총괄 / 부장[email protected]

Page 2: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

PLATFORM CONVERGENCE JOURNEY

Windows 10

ConvergedOS kernel

Convergedapp model

Page 3: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

ONE WINDOWS

PhoneSmall Tablet

2-in-1s(Tablet or Laptop)

Desktops & All-in-Ones

PhabletLargeTablet

Classic Laptop

Page 4: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

ONE WINDOWS

Internet of Things

PPIXbox

Page 5: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

ONE WINDOWS

PhoneSmall Tablet

2-in-1s(Tablet or Laptop)

Desktops & All-in-Ones

PhabletLargeTablet

Classic Laptop

Windows 10

Store

Development

Universal App

Page 6: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

First feedback

Page 7: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 8: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Start Menu & Power Button

Page 9: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Store App Run in a Window

Page 10: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Charms bar redesigned

Page 11: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

The Desktop Refined

Page 12: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Virtual Desktop

Page 13: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

To 4K and beyond.

Start Screen Enhanced

Notification Center

Storage Sense

Cortana

Page 14: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 15: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Visual Studio 2014

Page 16: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Visual Studio 2014

Page 17: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 18: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 19: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 20: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 21: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 22: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

C#

#if WINDOWS_PHONE_APP

Windows.Phone.UI.Input.HardwareButtons.BackPressed += this.HardwareButtons_BackPressed;

#endif

C++

#if WINAPI_FAMILY==WINAPI_FAMILY_PHONE_APP

_backPressedEventToken = HardwareButtons::BackPressed +=

ref new EventHandler<BackPressedEventArgs^>(this,

&NavigationHelper::HardwareButton_BackPressed);

#endif

Page 23: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 24: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 25: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 26: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 27: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 28: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Cross PlatformCreate native iOS, Android, Mac andWindows apps in Visual Studio and C#

All in one development toolCloud, Web, Embedded, IoT, BigData, Machine Learing …

Page 29: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

What is native?

Page 30: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

The Anatomy of a Native App

Native User Interfaces Native API Access Native Performance

Page 31: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Architecting

Mobile Apps

Page 32: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

The Silo Approach

Build App

Multiple Times

Page 33: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

The Write-Once-Run-Anywhere Approach

Lowest Common

Denominator

Page 34: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Xamarin’s Unique Approach

Native With

Code Sharing

Page 35: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Windows APIs

Page 36: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

iOS APIs | 100% Coverage

Page 37: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Android APIs | 100% Coverage

Page 38: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Xamarin.iOS does full Ahead Of Time

(AOT) compilation to produce an

ARM binary for Apple’s App Store.

Native Performance

Xamarin.Android takes advantage

of Just In Time (JIT) compilation on

the Android device.

Page 39: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 40: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 41: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Portable Class Libraries

Page 42: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Xamarin + Xamarin.Forms

With Xamarin.Forms:

more code-sharing, native controlsTraditional Xamarin approach

Shared UI Code

Page 43: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Xamarin + Xamarin.Forms

Shared UI Code

Quickly and easily build native user

interfaces using shared code

Xamarin.Forms elements map to

native controls and behaviors

Mix-and-match Xamarin.Forms with

native APIs

Page 44: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

What’s Included

40+ Pages, Layouts, and Controls

Build from code behind or XAML

Two-way Data Binding

Navigation

Animation API

Dependency Service

Messaging Center

Page 45: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Pages

Content MasterDetail Navigation Tabbed Carousel

Page 46: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Layouts

Stack Absolute Relative Grid ContentView ScrollView Frame

Page 47: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Controls

ActivityIndicator BoxView Button DatePicker Editor

Entry Image Label ListView Map

OpenGLView Picker ProgressBar SearchBar Slider

Stepper TableView TimePicker WebView EntryCell

ImageCell SwitchCell TextCell ViewCell

Page 48: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Login Page – XAML

Page 49: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Login Page

Page 50: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 51: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 52: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

$

Page 53: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

We participate in industry standards

like ISO 27001, SSAE16 and Cloud

Security Alliance.

Page 54: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 55: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

compute data services networks

N Central US, S Central US, N Europe, W Europe, E Asia,

SE Asia + 24 Edge CDN Locations

Automated

Managed Resources

Elastic

Usage Based

app services

Page 56: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 57: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 58: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 59: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 60: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 61: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 62: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 63: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Website

Socket Comm.

Mobile Service

Javascript

범용성

Page 64: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 65: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

puts("Enter your name: ");var name = gets();puts("Name: " + name);

puts("Enter your name: ");gets(function(name) {

puts("Name: " + name);});

Page 66: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 67: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 68: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 69: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 71: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 75: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 76: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 77: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Node.js (x86): http://nodejs.org/dist/v0.10.22/node-v0.10.22-x86.msi

(x64): http://nodejs.org/dist/v0.10.22/x64/node-v0.10.22-x64.msi

Visual Studio 2013 Downloadhttp://www.microsoft.com/visualstudio/eng/downloads#d-2013-editions

NTVS Downloadhttps://nodejstools.codeplex.com/wikipage?title=Installation#

Page 78: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 79: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

TypeScript, DART, & CoffeeScript

Micorsoft / Open Source Google / Open Source Jeremy Ashkenas / Open Source

Open Source

http://typescript.codeplex.com/

Open Source

https://code.google.com/p/dart/

Open Source

https://github.com/jashkenas/coffee-script/

http://coffeescript.org/http://www.dartlang.org/http://www.typescriptlang.org/

Page 81: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 82: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 83: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Azure Portal & ML API serviceAzure 고객사운영자

• 데이터과학자에게ML Studio workspace 생성

• 저장소계정발급

• ML 사용량모니터링

• 데이터과학자가완료한 API 게시/업데이트

Machine Learning

1ML Studio 데이터과학자

• 데이터를유형에맞게준비/조정

• 다양한모델을생성/학습/테스트수행

• 타업무자와협업

• API 서비스를이용해서비스구성

2

표준 REST API를사용함으로써

어디에서나어떤장치에서나접근가능Mobile AppsPowerBI/

DashboardsWeb Apps

ML API service 개발자

• C#, Python, R 코드를제공함• 기타다른언어도표준 REST API를사용함으로쉽게연동

3

HDInsight

로컬스토리지

Azure 스토리지

분석 대상 데이터

Page 84: 20141216 멜팅팟 부산   세션 ii - cross platform 개발
Page 85: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

Multi Platform Support

Page 86: 20141216 멜팅팟 부산   세션 ii - cross platform 개발

3

Windows Store iOS

Android

Windows Phone 8

iOS

Android

HTML 5/JS

SDKs

Server-Side

Scripts

&

Scheduler

기본기능

Page 87: 20141216 멜팅팟 부산   세션 ii - cross platform 개발