Git Product home page Git Product logo

uikit-cross-platform's Introduction

CircleCI Swift4.1 Platforms License codecov

UIKit-cross-platform

Your Swift UI Code on Android

UIKit-cross-platform is a UI framework for native apps, which enables code targeting iOS UIKit to run on other platforms, particularly on Android.

Goal

Currently in mobile development apps have to be written twice, for iOS and Android, or native performance has to be sacrificed with a cross-platform solution such as React Native.

This framework aims to combine both advantages, having native performance and writing code only once but still keeping a native look & feel.

How to run your iOS Project on Android

  1. Create new iOS Project or open an existing one
  2. Prepare your iOS Project
  3. Add UIKit-cross-platform to your project
  4. Run ./UIKit/create-android-project from the root of your iOS project
  5. Open ./android folder in Android Studio (install Android SDKs if necessary) and press "run" button

Try out the demo

This project includes a DemoApp which runs on iOS, Android and Mac.

How to run it on different platforms:

  1. Clone this project, cd into it and run git submodule update --init --recursive
  2. Open ./samples/getting-started/DemoApp.xcodeproj in Xcode
    1. Run DemoApp target for the iOS App
    2. Run DemoAppMac target for the Mac App
  3. Open ./samples/getting-started/android with Android Studio (install Android SDKs if necessary)
  4. Connect an Android device and press "Run" for the Android App

Additional setup instructions

Adding UIKit-cross-platform

UIKit-cross-platform has to be added as a dependency to your project including its subdependencies.

The recommended way is to use git submodules to add it to an UIKit subdirectory. In order to do so use the following command:

git submodule add [email protected]:flowkey/UIKit-cross-platform.git UIKit && git submodule update --init --recursive UIKit

Setup build environment

  1. Install Cmake > 3.16 and Ninja
brew install cmake && brew install ninja
  1. Install Android Studio
  2. Add SDKs in Android Studio
    1. Open Preferences in Android Studio
    2. Go to Appearance & Behavior -> System Settings -> Android SDK
    3. under SDK Platforms: tick checkbox for API Level 29 (latest should always work)
    4. under SDK Tools, tick the box for Android SDK Tools
    5. Press Apply / OK to install SDKs

Architecture

UIKit-cross-platform renders with SDL_gpu which translates down to lower-level OpenGL instructions.

On Android, Swift Package Manager compiles Swift Code into native binaries, which are called through the NDK.

More detailed information about the architecture can be found here

API documentation

This framework uses the Apple UIKit API, therefore the official Apple Docs serve as documentation for the already implemented features.

How to contribute

Contributions are very welcome and helpful ๐Ÿ™Œ

If you are looking for a feature or find a bug, please create an Issue.

For additional information please refer to our contribution guidelines.

FAQs / Troubleshooting

Our FAQs can be found here (Work In Progress).

Please contact us regarding upcoming issues on Spectrum or create a new Issue.

License

UIKit-cross-platform is free software; you can redistribute it and/or modify it under the terms of the MIT License.

uikit-cross-platform's People

Contributors

ephemer avatar cshg avatar michaelknoch avatar rikner avatar janek avatar mouselangelo avatar lightningboss avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.