ti-enxame.com

Como criar Android aplicativo com widget de aplicativo em um único aplicativo

Eu já fiz um aplicativo Android que armazena a data com o nome da pessoa e o número de telefone.

Agora eu tenho que desenvolver um widget para que este aplicativo mostre hoje (data, nome da pessoa e número de telefone) com o botão.

Requisitos:

  1. Aplicativo único com aplicativo e widget.
  2. Quando clico em um botão que está no widget, ele inicia o meu aplicativo.
  3. Os dados do widget sempre devem ser sincronizados com meu aplicativo - quando o dia de hoje (a pessoa 5 e o aplicativo adicionam mais 5 pessoas, o widget exibe 10 dados da pessoa)
  4. Como posso projetar esse widget? Alguma orientação? Eu tenho que usar o ScrollView horizontal.

Fiz uma demonstração simples do widget, mas não sei como sincronizá-lo com o meu aplicativo.

Compartilhe sua experiência e dê uma idéia sobre meu widget e aplicativo.

37
Harshid

Estou descobrindo alguns dias em que tenho a solução. Então, estou compartilhando minha ideia.

Este site tem sido muito útil para mim.

http://kasperholtze.com/Android/how-to-make-a-simple-Android-widget/

Fiz algumas alterações e fiz o meu trabalho.

Solução de requisitos:

1. Faça o receptor e coloque em permissão manifesta como esta.

<receiver
        Android:name=".WatchWidget"
        Android:label="WatchWidget" >
        <intent-filter>
            <action Android:name="Android.appwidget.action.APPWIDGET_UPDATE" />
        </intent-filter>
        <meta-data
            Android:name="Android.appwidget.provider"
            Android:resource="@xml/watch_widget_provider" />
    </receiver>

2.. Ao meu lado, solicite o TextView superior, clique para que você possa usar o TextView id em onUpdate().

    remoteViews = new RemoteViews(context.getPackageName(),R.layout.widget_lay);

    Intent intent = new Intent(context, TestActivity.class);
    intent.setAction("callActivity");
    PendingIntent pendingIntent = PendingIntent.getActivity(context, 0, intent, 0);
    remoteViews.setOnClickPendingIntent(R.id.widget_textview, pendingIntent); 
    appWidgetManager.updateAppWidget(new ComponentName(context,WatchWidget.class), remoteViews);

3. Quero chamar o banco de dados e buscar o registro e exibi-lo. Agora pergunte o que dizer da atualização?

Então, eu usei a classe timer e execute cada 1000seg porque o over widget é sempre atualizado 30min (pode ser).

@Override
public void onUpdate( final Context context, final AppWidgetManager appWidgetManager, final int[] appWidgetIds )
{

    this.appWidgetManager = appWidgetManager;
    try {
        Timer timer = new Timer();
        timer.scheduleAtFixedRate(new MyTime(context, appWidgetManager,appWidgetIds), 1, 1000);

    } catch (Exception e) {
        System.out.println("Exception:");
    }
    updateSwitch1(context, appWidgetManager, appWidgetIds[0]);

}

Se houver alguma dúvida, faça um comentário e obrigado a todos que me deram total apoio para tornar essa resposta útil.

8
Harshid

Criar e configurar widget

Para registrar um widget, você cria um BroadcastReceiver com um filtro de intenção para a ação Android.appwidget.action.APPWIDGET_UPDATE.

<receiver
       Android:icon="@drawable/icon"
       Android:label="Example Widget"
       Android:name="MyWidgetProvider" >
       <intent-filter >
            <action Android:name="Android.appwidget.action.APPWIDGET_UPDATE" />
       </intent-filter>

       <meta-data
          Android:name="Android.appwidget.provider"
          Android:resource="@xml/widget_info" />
</receiver> 

Você também especifica os metadados para o widget por meio do atributo Android: name = "Android.appwidget.provider. O arquivo de configuração referido por esses metadados contém as configurações do widget. Se, por exemplo, a interface de atualização, o tamanho e o layout inicial do widget.

Crie um novo arquivo myshape.xml no diretório/res/drawable. Este arquivo definirá o plano de fundo que usamos no seu widget.

<?xml version="1.0" encoding="UTF-8"?>
<shape xmlns:Android="http://schemas.Android.com/apk/res/Android"
           Android:shape="rectangle" >

    <stroke
        Android:width="2dp"
        Android:color="#FFFFFFFF" />

    <gradient
        Android:angle="225"
        Android:endColor="#DD2ECCFA"
        Android:startColor="#DD000000" />

    <corners
        Android:bottomLeftRadius="7dp"
        Android:bottomRightRadius="7dp"
        Android:topLeftRadius="7dp"
        Android:topRightRadius="7dp" />

</shape> 

Defina o seguinte widget_layout.xml na pasta res/layout.

<?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
          Android:id="@+id/layout"
          Android:layout_width="match_parent"
          Android:layout_height="match_parent"
          Android:layout_margin="8dip"
          Android:background="@drawable/myshape" >

        <TextView
            Android:id="@+id/update"
            style="@Android:style/TextAppearance.Medium"
            Android:layout_width="match_parent"
            Android:layout_height="match_parent"
            Android:layout_gravity="center"
            Android:gravity="center_horizontal|center_vertical"
            Android:layout_margin="4dip"
            Android:text="Static Text" >
        </TextView>

    </LinearLayout> 

agora faça a aula.

public class MyWidgetProvider extends AppWidgetProvider {

  private static final String ACTION_CLICK = "ACTION_CLICK";  

     @Override
  public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {

    // Get all ids
    ComponentName thisWidget = new ComponentName(context,
        MyWidgetProvider.class);
    int[] allWidgetIds = appWidgetManager.getAppWidgetIds(thisWidget);
    for (int widgetId : allWidgetIds) {
      // Create some random data
      int number = (new Random().nextInt(100));

      RemoteViews remoteViews = new RemoteViews(context.getPackageName(),
          R.layout.widget_layout);
      Log.w("WidgetExample", String.valueOf(number));
      // Set the text
      remoteViews.setTextViewText(R.id.update, String.valueOf(number));

      // Register an onClickListener
      Intent intent = new Intent(context, MyWidgetProvider.class);

      intent.setAction(AppWidgetManager.ACTION_APPWIDGET_UPDATE);
      intent.putExtra(AppWidgetManager.EXTRA_APPWIDGET_IDS, appWidgetIds);

      PendingIntent pendingIntent = PendingIntent.getBroadcast(context,
          0, intent, PendingIntent.FLAG_UPDATE_CURRENT);
      remoteViews.setOnClickPendingIntent(R.id.update, pendingIntent);
      appWidgetManager.updateAppWidget(widgetId, remoteViews);
    }
  }
36
Roadies