Globales Ranking · von 600 Skills
flutter-adding-home-screen-widgets AI Agent Skill
Quellcode ansehen: flutter/skills
SafeInstallation
npx skills add flutter/skills --skill flutter-adding-home-screen-widgets 6.1K
Installationen
Implementing Flutter Home Screen Widgets
Contents
- Architecture & Data Flow
- Flutter Integration Workflow
- iOS Implementation Workflow
- Android Implementation Workflow
- Advanced Techniques
- Examples
Architecture & Data Flow
Home Screen Widgets require native UI implementation (SwiftUI for iOS, XML/Kotlin for Android). The Flutter app communicates with these native widgets via shared local storage (UserDefaults on iOS, SharedPreferences on Android) using the home_widget package.
- Data Write: Flutter app writes key-value pairs or renders images to a shared container.
- Trigger: Flutter app signals the native OS to update the widget.
- Data Read: Native widget wakes up, reads the key-value pairs or images from the shared container, and updates its UI.
Flutter Integration Workflow
Use this checklist to implement the Dart side of the Home Screen Widget integration.
- Step 1: Initialize the App Group. Call
HomeWidget.setAppGroupId('<YOUR_APP_GROUP>')ininitState()or app startup. - Step 2: Save Data. Use
HomeWidget.saveWidgetData<T>('key', value)to write data to shared storage. - Step 3: Trigger Update. Call
HomeWidget.updateWidget(iOSName: 'YourIOSWidget', androidName: 'YourAndroidWidget')to notify the OS. - Step 4: Validate. Run Flutter build -> review console for missing plugin registrations -> fix.
iOS Implementation Workflow
If targeting iOS, implement the widget using Xcode and SwiftUI.
- Step 1: Create Target. Open
ios/Runner.xcworkspacein Xcode. Add a new Widget Extension target. Disable "Include Live Activity" and "Include Configuration Intent" unless explicitly required. - Step 2: Configure App Groups. Add the App Groups capability to both the Runner target and the Widget Extension target. Ensure the App Group ID matches the one used in Dart.
- Step 3: Define TimelineEntry. Create a struct conforming to
TimelineEntryto hold the data passed from shared storage. - Step 4: Implement TimelineProvider.
- In
getSnapshotandgetTimeline, instantiateUserDefaults(suiteName: "<YOUR_APP_GROUP>"). - Extract values using
userDefaults?.string(forKey: "your_key"). - Return the populated
TimelineEntry.
- In
- Step 5: Build UI. Implement the SwiftUI
Viewto display the data from theTimelineEntry. - Step 6: Validate. Run Xcode build for the Widget Extension -> review provisioning/App Group errors -> fix.
Android Implementation Workflow
If targeting Android, implement the widget using Android Studio and XML/Kotlin.
- Step 1: Create App Widget. Open the
androidfolder in Android Studio. Right-click the app directory -> New -> Widget -> App Widget. - Step 2: Define Layout. Edit
res/layout/<widget_name>.xmlto define the UI using standard Android XML layouts (e.g.,RelativeLayout,TextView,ImageView). - Step 3: Implement AppWidgetProvider.
- Open the generated Kotlin class extending
AppWidgetProvider. - In the
onUpdatemethod, retrieve shared data usingHomeWidgetPlugin.getData(context). - Extract values using
widgetData.getString("your_key", null). - Update the UI using
RemoteViewsandsetTextViewTextorsetImageViewBitmap. - Call
appWidgetManager.updateAppWidget(appWidgetId, views).
- Open the generated Kotlin class extending
- Step 4: Validate. Run Android build -> review Manifest registration errors -> fix.
Advanced Techniques
Rendering Flutter Widgets as Images
If the UI is too complex to recreate natively (e.g., custom charts), render the Flutter widget to an image and display the image in the native widget.
- Wrap the target Flutter widget with a
GlobalKey. - Call
HomeWidget.renderFlutterWidget(), passing the widget, a filename, and the key. - iOS: Read the file path from
UserDefaultsand render usingUIImage(contentsOfFile:)inside a SwiftUIImage. - Android: Read the file path from
SharedPreferences, decode usingBitmapFactory.decodeFile(), and render usingsetImageViewBitmap().
Using Custom Flutter Fonts (iOS Only)
If utilizing custom fonts defined in Flutter on iOS Home Screen Widgets:
- Extract the Flutter asset bundle path in Swift.
- Register the font using
CTFontManagerRegisterFontsForURL. - Apply the font in SwiftUI using
Font.custom().
Examples
Example: Flutter Data Update
import 'package:home_widget/home_widget.dart';
const String appGroupId = 'group.com.example.app';
const String iOSWidgetName = 'NewsWidgets';
const String androidWidgetName = 'NewsWidget';
Future<void> updateWidgetData(String title, String description) async {
await HomeWidget.setAppGroupId(appGroupId);
await HomeWidget.saveWidgetData<String>('headline_title', title);
await HomeWidget.saveWidgetData<String>('headline_description', description);
await HomeWidget.updateWidget(
iOSName: iOSWidgetName,
androidName: androidWidgetName,
);
}Example: iOS SwiftUI Provider & View
import WidgetKit
import SwiftUI
struct NewsArticleEntry: TimelineEntry {
let date: Date
let title: String
let description: String
}
struct Provider: TimelineProvider {
func placeholder(in context: Context) -> NewsArticleEntry {
NewsArticleEntry(date: Date(), title: "Loading...", description: "Loading...")
}
func getSnapshot(in context: Context, completion: @escaping (NewsArticleEntry) -> ()) {
let userDefaults = UserDefaults(suiteName: "group.com.example.app")
let title = userDefaults?.string(forKey: "headline_title") ?? "No Title"
let description = userDefaults?.string(forKey: "headline_description") ?? "No Description"
let entry = NewsArticleEntry(date: Date(), title: title, description: description)
completion(entry)
}
func getTimeline(in context: Context, completion: @escaping (Timeline<Entry>) -> ()) {
getSnapshot(in: context) { (entry) in
let timeline = Timeline(entries: [entry], policy: .atEnd)
completion(timeline)
}
}
}
struct NewsWidgetsEntryView : View {
var entry: Provider.Entry
var body: some View {
VStack(alignment: .leading) {
Text(entry.title).font(.headline)
Text(entry.description).font(.subheadline)
}
}
}Example: Android Kotlin Provider
package com.example.app.widgets
import android.appwidget.AppWidgetManager
import android.appwidget.AppWidgetProvider
import android.content.Context
import android.widget.RemoteViews
import es.antonborri.home_widget.HomeWidgetPlugin
import com.example.app.R
class NewsWidget : AppWidgetProvider() {
override fun onUpdate(
context: Context,
appWidgetManager: AppWidgetManager,
appWidgetIds: IntArray,
) {
for (appWidgetId in appWidgetIds) {
val widgetData = HomeWidgetPlugin.getData(context)
val views = RemoteViews(context.packageName, R.layout.news_widget).apply {
val title = widgetData.getString("headline_title", "No Title")
setTextViewText(R.id.headline_title, title)
val description = widgetData.getString("headline_description", "No Description")
setTextViewText(R.id.headline_description, description)
}
appWidgetManager.updateAppWidget(appWidgetId, views)
}
}
}Example: iOS Custom Font Registration Helper
// Add this to your SwiftUI View struct
var bundle: URL {
let bundle = Bundle.main
if bundle.bundleURL.pathExtension == "appex" {
var url = bundle.bundleURL.deletingLastPathComponent().deletingLastPathComponent()
url.append(component: "Frameworks/App.framework/flutter_assets")
return url
}
return bundle.bundleURL
}
init(entry: Provider.Entry) {
self.entry = entry
CTFontManagerRegisterFontsForURL(
bundle.appending(path: "/fonts/YourCustomFont.ttf") as CFURL,
CTFontManagerScope.process,
nil
)
}Installationen
Sicherheitsprüfung
Quellcode ansehen
flutter/skills
Mehr aus dieser Quelle
Power your AI Agents with
the best open-source models.
Drop-in OpenAI-compatible API. No data leaves Europe.
Explore Inference APIGLM
GLM 5
$1.00 / $3.20
per M tokens
Kimi
Kimi K2.5
$0.60 / $2.80
per M tokens
MiniMax
MiniMax M2.5
$0.30 / $1.20
per M tokens
Qwen
Qwen3.5 122B
$0.40 / $3.00
per M tokens
So verwenden Sie diesen Skill
Install flutter-adding-home-screen-widgets by running npx skills add flutter/skills --skill flutter-adding-home-screen-widgets in your project directory. Führen Sie den obigen Installationsbefehl in Ihrem Projektverzeichnis aus. Die Skill-Datei wird von GitHub heruntergeladen und in Ihrem Projekt platziert.
Keine Konfiguration erforderlich. Ihr KI-Agent (Claude Code, Cursor, Windsurf usw.) erkennt installierte Skills automatisch und nutzt sie als Kontext bei der Code-Generierung.
Der Skill verbessert das Verständnis Ihres Agenten für flutter-adding-home-screen-widgets, und hilft ihm, etablierte Muster zu befolgen, häufige Fehler zu vermeiden und produktionsreifen Code zu erzeugen.
Was Sie erhalten
Skills sind Klartext-Anweisungsdateien — kein ausführbarer Code. Sie kodieren Expertenwissen über Frameworks, Sprachen oder Tools, das Ihr KI-Agent liest, um seine Ausgabe zu verbessern. Das bedeutet null Laufzeit-Overhead, keine Abhängigkeitskonflikte und volle Transparenz: Sie können jede Anweisung vor der Installation lesen und prüfen.
Kompatibilität
Dieser Skill funktioniert mit jedem KI-Coding-Agenten, der das skills.sh-Format unterstützt, einschließlich Claude Code (Anthropic), Cursor, Windsurf, Cline, Aider und anderen Tools, die projektbezogene Kontextdateien lesen. Skills sind auf Transportebene framework-agnostisch — der Inhalt bestimmt, für welche Sprache oder welches Framework er gilt.
Chat with 100+ AI Models in one App.
Use Claude, ChatGPT, Gemini alongside with EU-Hosted Models like Deepseek, GLM-5, Kimi K2.5 and many more.