All Projects → fengdai → Alertdialogpro

fengdai / Alertdialogpro

Licence: other
[Deprecated] This project can make it easy to theme and custom Android's dialog. Also provides Holo and Material themes for old devices.

Programming Languages

java
68154 projects - #9 most used programming language

Projects that are alternatives of or similar to Alertdialogpro

Typecho Theme Material
Material Design theme for typecho.
Stars: ✭ 366 (-21.46%)
Mutual labels:  material-theme
Appupdater
🚀 AppUpdater一个专注于App更新,一键傻瓜式集成App版本升级的轻量开源库。(无需担心通知栏适配;无需担心重复点击下载;无需担心App安装等问题;这些AppUpdater都已帮您处理好。)
Stars: ✭ 406 (-12.88%)
Mutual labels:  dialog
Smart Show
Toast & Snackbar & TopBar & Dialog
Stars: ✭ 430 (-7.73%)
Mutual labels:  dialog
Svelte Materialify
A Material UI Design Component library for Svelte heavily inspired by vuetify.
Stars: ✭ 351 (-24.68%)
Mutual labels:  material-theme
Imguifiledialog
File Dialog for ImGui : https://github.com/aiekick/ImGuiFileDialog
Stars: ✭ 398 (-14.59%)
Mutual labels:  dialog
Fancygifdialog Android
Make your native android Dialog Fancy and Gify. A library that takes the standard Android Dialog to the next level with a variety of styling options and Gif's. Style your dialog from code.
Stars: ✭ 409 (-12.23%)
Mutual labels:  dialog
Aestheticdialogs
📱 An Android Library for 💫fluid, 😍beautiful, 🎨custom Dialogs.
Stars: ✭ 352 (-24.46%)
Mutual labels:  dialog
React Cool Portal
😎 🍒 React hook for Portals, which renders modals, dropdowns, tooltips etc. to <body> or else.
Stars: ✭ 458 (-1.72%)
Mutual labels:  dialog
Vue Material Dashboard
Vue Material Dashboard - Open Source Material Design Admin
Stars: ✭ 403 (-13.52%)
Mutual labels:  material-theme
Gijgo
Gijgo - Free Javascript Controls
Stars: ✭ 424 (-9.01%)
Mutual labels:  dialog
Django Private Chat
Django one-to-one Websocket-based Asyncio-handled chat, developed by Bearle team
Stars: ✭ 376 (-19.31%)
Mutual labels:  dialog
React Native Awesome Alerts
Awesome alerts for React Native, works with iOS and Android.
Stars: ✭ 391 (-16.09%)
Mutual labels:  dialog
React Native Actions Sheet
A Cross Platform(Android & iOS) ActionSheet with a flexible api, native performance and zero dependency code for react native. Create anything you want inside ActionSheet.
Stars: ✭ 412 (-11.59%)
Mutual labels:  dialog
Popupdialog
A simple, customizable popup dialog for iOS written in Swift. Replaces UIAlertController alert style.
Stars: ✭ 3,709 (+695.92%)
Mutual labels:  dialog
Mmf
A modular framework for vision & language multimodal research from Facebook AI Research (FAIR)
Stars: ✭ 4,713 (+911.37%)
Mutual labels:  dialog
Android Switchdatetimepicker
Android library for Date and Time Picker in same dialog
Stars: ✭ 360 (-22.75%)
Mutual labels:  dialog
Colorpickerpreference
🎨 A library that lets you implement ColorPicker, ColorPickerDialog, ColorPickerPreference.
Stars: ✭ 407 (-12.66%)
Mutual labels:  dialog
Seq2seqchatbots
A wrapper around tensor2tensor to flexibly train, interact, and generate data for neural chatbots.
Stars: ✭ 466 (+0%)
Mutual labels:  dialog
Sppermissions
Ask permissions with ready-use interface. You can check status permission and if it has been requested before. Support SwiftUI.
Stars: ✭ 4,701 (+908.8%)
Mutual labels:  dialog
Dialogic
💬 Create dialogs, characters and scenes to display conversations in your Godot games.
Stars: ✭ 414 (-11.16%)
Mutual labels:  dialog

Build Status Android Arsenal

Deprecated

Please use android.support.v7.app.AlertDialog of support-v7.

AlertDialogPro

Why AlertDialogPro?

Theming Android's AlertDialog is not an easy thing. Because some of its attributes are not avaliable on old platform. Even on newer you still can't use android:layout to specify your own layout, since your views' ids should be consistant with Android's, some of which are not public... AlertDialogPro can make theming a lot easier.

holo-light mtrl-light flavored-mtrl-light mtrl-dark

Structure

alertdialogpro-core

Contains core codes for building an AlertDialogPro. Most of it's codes are ported from the latest Android Platform. It doesn't contain any resource file. If you want to implement a brand new theme, use this project directly. Otherwise, you should use alertdialogpro-theme-material or alertdialogpro-theme-holo.

alertdialogpro-theme-material

Based on alertdialogpro-core, gives AlertDialogPro a Material theme.

alertdialogpro-theme-holo (Obsolete)

Also based on alertdialogpro-core, gives AlertDialogPro a Holo theme.

Quick Start

Take alertdialogpro-theme-material for example.

Download

Grab latest version via Gradle:

dependencies {
  compile 'com.github.fengdai:alertdialogpro-theme-material:0.2.6'
}

or Maven:

<dependency>
  <groupId>com.github.fengdai</groupId>
  <artifactId>alertdialogpro-theme-material</artifactId>
  <version>0.2.6</version>
</dependency>

Specify AlertDialogPro's theme

In your app's xml file, use attribute alertDialogProTheme to specify your AlertDialogPro's theme. alertdialogpro-theme-material contains two built-in theme: Theme.AlertDialogPro.Material and Theme.AlertDialogPro.Material.Light. Here, we use the light version:

<style name="YourAppTheme">
   ...
  <item name="alertDialogProTheme">@style/Theme.AlertDialogPro.Material.Light</item>
</style>

Build an AlertDialogPro

Use AlertDialogPro.Builder to build an AlertDialogPro:

AlertDialogPro.Builder builder = new AlertDialogPro.Builder(getContext());
builder.setIcon(R.drawable.icon).
        setTitle("Title").
        setMessage("Message Body").
        setNeutralButton("Neutral", null).
        setPositiveButton("Positive", null).
        setNegativeButton("Negative", null).
        show();

With the example codes above, you can create an AlertDialogPro which has an icon, a title, a message body and three option buttons. Look into the sample to see more usages.

Flavor built-in themes

Built-in themes can't meet your requirement? There are several attributes that you can use to make some slight changes. Here is an example to show how to change the positive button's color:

  1. Define your positive button's style:
<style name="YourButtonStyle" parent="Widget.AlertDialogPro.Material.Light.Button">
     <item name="android:textColor">@color/adp_positive_button_color</item>
</style>
  1. Specify button style to your AlertDialogPro's theme with attribute adpButtonBarPositiveButtonStyle:
<style name="FlavoredMaterialLight" parent="Theme.AlertDialogPro.Material.Light">
      ...
     <item name="adpButtonBarPositiveButtonStyle">@style/YourButtonStyle</item>
</style>
  1. Use it in your app's theme:
<item name="alertDialogProTheme">@style/FlavoredMaterialLight</item>

Look into here to see all attributes.

Advanced customization

You can specify your own layout to AlertDialogPro. This can be very useful when you want to use custom views or you want a special dialog layout. Remember to keep your views' ids consistant with AlertDialogPro's ids.

  1. Define your AlertDialogPro's style:
<style name="YourAlertDialogProStyle" parent="AlertDialogPro.Material.Light">
  <!-- Specify your AlertDialogPro's layout -->
  <item name="adpLayout">@layout/your_alert_dialog</item>
  <!-- Specify your AlertDialogPro's ListView layout. -->
  <item name="adpListLayout">@layout/your_list_layout</item>
  <!-- Specify your AlertDialogPro's list item layout. -->
  <item name="adpListItemLayout">@layout/your_dialog_item</item>
  <!-- Specify your AlertDialogPro's multi choice list item layout. -->
  <item name="adpMultiChoiceItemLayout">@layout/your_multichoice_dialog_item</item>
  <!-- Specify your AlertDialogPro's single choice list item layout. -->
  <item name="adpSingleChoiceItemLayout">@layout/your_singlechoice_dialog_item</item>
</style>
  1. And add it to your AlertDialogPro's theme:
<style name="YourAlertDialogProTheme" parent="Theme.AlertDialogPro.Material.Light">
  ...
  <item name="alertDialogProStyle">@style/YourAlertDialogProStyle</item>
</style>
  1. Use your AlertDialogPro theme in your app's theme:
<item name="alertDialogProTheme">@style/YourAlertDialogProTheme</item>

Migrate From AlertDialog

AlertDialogPro's Java API is exactly the same as AlertDialog's. In fact, most of AlertDialogPro's codes are ported from the latest AlertDialog. So the only thing you need to do in your Java codes is replacing AlertDialog.Builder with AlertDialogPro.Builder.

Requirements

AlertDialogPro requires at minimum Android 2.1 (API level 7).

Thanks

License

Copyright (C) 2014 Feng Dai
Copyright (C) 2007 The Android Open Source Project

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].