All Projects → tslamic → Androiddevicenames

tslamic / Androiddevicenames

A tiny Android library that transforms the device model name into something users can understand.

Programming Languages

kotlin
9241 projects

Projects that are alternatives of or similar to Androiddevicenames

Libosmscout
Libosmscout is a C++ library for offline map rendering, routing and location lookup based on OpenStreetMap data
Stars: ✭ 159 (-19.7%)
Mutual labels:  library, offline
Kiwix Tools
Command line Kiwix tools: kiwix-serve, kiwix-manage, ...
Stars: ✭ 139 (-29.8%)
Mutual labels:  library, offline
Collections C
A library of generic data structures.
Stars: ✭ 2,297 (+1060.1%)
Mutual labels:  library
Paco
Small utility library for coroutine-driven asynchronous generic programming in Python 3.4+
Stars: ✭ 198 (+0%)
Mutual labels:  library
Newsapi Python
A Python Client for News API
Stars: ✭ 196 (-1.01%)
Mutual labels:  library
C Macro Collections
Easy to use, header only, macro generated, generic and type-safe Data Structures in C
Stars: ✭ 192 (-3.03%)
Mutual labels:  library
Angular Library Seed
🌾 Seed project for Angular libraries that are AOT/JIT compatible and that use external SCSS-styles and HTML-templates
Stars: ✭ 197 (-0.51%)
Mutual labels:  library
Intercept
A C/C++ Binding Library for SQF and RV Engine Access Abstraction Layer
Stars: ✭ 191 (-3.54%)
Mutual labels:  library
Duaef duik
Duduf After Effects Framework | Duik
Stars: ✭ 197 (-0.51%)
Mutual labels:  library
Contour
Modern C++ Terminal Emulator
Stars: ✭ 191 (-3.54%)
Mutual labels:  library
Aegis.cpp
Discord C++ library for interfacing with the API. Join our server:
Stars: ✭ 198 (+0%)
Mutual labels:  library
Truly Ui
Truly-UI - Web Angular UI Components for Desktop Applications (Electron, NW, APP JS)
Stars: ✭ 195 (-1.52%)
Mutual labels:  library
Offline Qr Code
📱 Browser add-on allowing you to quickly generate a QR code offline with the URL of the open tab or other text!
Stars: ✭ 193 (-2.53%)
Mutual labels:  offline
Libmobi
C library for handling Kindle (MOBI) formats of ebook documents
Stars: ✭ 197 (-0.51%)
Mutual labels:  library
Marqueeviewlibrary
一个帮您快速实现跑马灯效果的library
Stars: ✭ 2,249 (+1035.86%)
Mutual labels:  library
Python Trezor
🐍 Don't use this repo, use the new monorepo instead:
Stars: ✭ 198 (+0%)
Mutual labels:  library
Library Management System
📚 An automated library management system developed in Laravel 4.2 PHP MVC Framework
Stars: ✭ 189 (-4.55%)
Mutual labels:  library
Golib
Go Library [DEPRECATED]
Stars: ✭ 194 (-2.02%)
Mutual labels:  library
Go Ykpiv
Golang interface to manage Yubikeys, including a crypto.Signer & crypto.Decrypter interface
Stars: ✭ 196 (-1.01%)
Mutual labels:  library
Messenger4j
A Java library for building Chatbots on the Facebook Messenger Platform - easy and fast.
Stars: ✭ 199 (+0.51%)
Mutual labels:  library

Android Device Names Build Status

This tiny Android library transforms a device model name into something people can understand. For example, a useless SM-N910W8 becomes Samsung Galaxy Note4 with a single method call. 🎉 It currently recognizes about 15k devices, including all Google Play supported devices.

It does not require network connectivity, ever. No, really.

To use it, add the following to your list of dependencies:

compile 'com.github.tslamic:dn3:3.0'

There are two classes you can use:

  1. DeviceNames use this if all you need is a single query.
  2. DeviceNamesDatabase for multiple queries. Don't forget to close it afterwards!

RxJava2 is supported out of the box. Obtaining a DeviceNames instance is easy:

AndroidDeviceNames.deviceNames(context)
  .subscribeOn(Schedulers.io())
  .observeOn(AndroidSchedulers.mainThread())
  .subscribe(names -> doSomethingWith(names));

but good ol' callbacks are supported too, in case you don't feel reactive:

AndroidDeviceNames.deviceNames(context,
  new AndroidDeviceNames.Callback<DeviceNames>() {
    @Override 
    public void onReady(@NonNull DeviceNames instance) {
      String name = instance.currentDeviceName(); 
    }
  });

You can obtain an instance of DeviceNamesDatabase in a similar fashion. After you're done using it, don't forget to explicitly call close(). For example:

@Override
protected void onStart() {
  super.onStart();
  AndroidDeviceNames.deviceNamesDatabase(this,
    new AndroidDeviceNames.Callback<DeviceNamesDatabase>() {
      @Override
      public void onReady(@NonNull DeviceNamesDatabase instance) {
        database = instance;
      }
    });
}

@Override
protected void onStop() {
  super.onStop();
  if (database != null) {
    database.close();
  }
}

Both DeviceNames and DeviceNamesDatabase come with three methods:

method description
currentDeviceName() Returns a user-friendly current device name, or null if the model is unknown.
currentDeviceName(String fallback) Same as above, but returns fallback if the model is unknown.
deviceName(String model, String fallback) Returns a user-friendly name for the specified model, or fallback, if model is unknown.

Not backwards compatible with v1 or v2, sorry.

If you've been using AndroidDeviceNames v1 or v2, please note that this version is not backwards compatible. Updating should be trivial, result in minimal code change and is highly encouraged.

Contributions

Special thanks to @corcoran for making numerous improvements to the lib.

In the wild

Here's the list of apps using this lib:

If you're using it in your app, and want to be on the above list, please let me know (create a pull request or open an issue).

License

Copyright 2017 Tadej Slamic

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].