Unsere Android-Plattform besteht aus nacheinander aufeinanderfolgenden Aktivitäten und jede Aktivität besteht aus einer oder mehreren Ansichten.
Wenn wir also eine Schnittstelle anzeigen möchten, denken wir zunächst daran, eine Aktivität zu erstellen, und dann werden alle Vorgänge in der Aktivität oder einem Dialog oder Toast implementiert. Diese Methode ist sicherlich einfach, aber in einigen Fällen benötigen wir lediglich eine einfache Anzeige, und die Verwendung von Aktivität ist offensichtlich überflüssig. Wie sollen wir zu diesem Zeitpunkt damit umgehen?
Eine Android-Anwendung ist auf der untersten Ebene ebenfalls ein Linux-Prozess, aber das Konzept des Prozesses ist auf der oberen Ebene abgeschwächt und abstrahiert die Interaktion der Aktivität. Der Code steuert die Aktivität direkt, und die Interaktion des Benutzers ist auch die Aktivität.
Aktivität ist ein Objekt, das aus der Perspektive der Benutzerinteraktion abstrahiert und in Konzept und Verwendung vom Prozess isoliert ist. Der Prozess ähnelt einer Adoptionsfunktion. Er kann nicht nur die Aktivität seiner aktuellen Anwendung übernehmen, sondern auch die Aktivitäten, die von anderen Installationspaketen für den Prozess angegeben werden. Der Prozess wird nicht zerstört (es sei denn, das System verlangt oder der Code erzwingt das Beenden des Prozesses).
auch Ansichten vom Bildschirm löschen. Das Objekt, dem es gegenübersteht, ist der Bildschirm an einem Ende und die Ansicht am anderen Ende. Es ignoriert direkt unsere vorherige Aktivität
oder unseren vorherigen Dialog. Tatsächlich erfolgt die zugrunde liegende Implementierung unserer Aktivität oder Diolog ebenfalls über WindowManager. Dieser
WindowManager ist global und das gesamte System ist das einzige. Es ist die unterste Ebene, die die Ansicht anzeigt.
Java-Code
WindowManager mWm = (WindowManager)getSystemService(Context.WINDOW_SERVICE); Button view = new Button(this); view.setText("window manager test!"); WindowManager.LayoutParams mParams = new WindowManager.LayoutParams(); mWm.addView(view, mParams);
Wenn ein Ansichtsobjekt erstellt wird, kennt Android seine Größe nicht, daher sind die von getWidth() und getHeight() zurückgegebenen Ergebnisse 0,
Die tatsächliche Größe wird berechnet, wenn das Layout erstellt wird Sie werden also eine interessante Sache finden, nämlich den Grund, warum Länge und Breite in onDraw() ermittelt werden können.
WindowManager.LayoutParams params; params = new WindowManager.LayoutParams( ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT, WindowManager.LayoutParams.TYPE_PHONE,//TYPE_APPLICATION, WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE, PixelFormat.TRANSLUCENT); params.gravity = Gravity.TOP; manager.addView(tmpView, params);
if(view.getParent==null)//如果view没有被加入到某个父组件中,则加入WindowManager中 wManager.addView(view,wmParams);
if(view.getParent()!=null) wManager.removeView(view);
2. Probleme mit dem Anwendungslebenszyklus
Wenn andere Anwendungen vor der Hauptaktivität des Browsers angezeigt werden, tritt der Lebenszyklus des Browsers in die OnPause ein, unabhängig davon, wie viele Browser-Unterfenster davor angezeigt werden Zustand.