[Neuling] Android Studio App erstellen mit iFrame und Autojustierung ?

W

Wurstboy

Neues Mitglied
0
Schönen guten Abend,

Ich bin der Marvin und komme aus dem schönen kleinen Örtchen Wallinghausen.
Ich bin relative neu in dieser Branche und wollte mir eine App kreieren mit einem iFrame und einer Autojustierung das diese iFrame Seite auch immer die richtige größe für jegliche Tablets, Handys o.ä hat.

Die App soll eigentlich nur aus einem iFrame bestehen und der Autojustierung.
Sprich wenn ich die App starte geht eine Seite in der App auf ( kein Browser, nur die Seite in dem iFrame )
und mehr sollte auch nicht in der App enthalten sein.

Hoffe ihr versteht wie ich das meine und könntet mir eventuell etwas unter die Arme greifen da ich sehr sehr frisch bin.

Ich freue mich schon auf eure Antworten :)

MfG Marvin.
 
Erst einmal vielen Dank für deine Hilfe.
Leider habe ich doch noch eine Hilfe nötig.

Ich habe mir soweit Android Studio 2.1.3 geholt.
Java 1.8 & das läuft auch alles gut.
Jetzt habe ich mir eine App erstellt.
Ich habe alles so gelassen , NUR

FullscreenActivity : (Makiert was ich geändert , bzw dazugefügt habe )

Android Manifest : (Unten eingerahmt könnt ihr auch nochmal den Fehler nachlesen den er mir gibt )
Das habe ich noch dazugefügt ganz oben :
<uses-permission android:name"android.permission.INTERNET"<>/uses-permission>

Was ist schief gelaufen ?
 

Anhänge

  • FullscreenActivity.jpg
    FullscreenActivity.jpg
    156,2 KB · Aufrufe: 222
  • AndroidManifest.jpg
    AndroidManifest.jpg
    172,7 KB · Aufrufe: 219
Zuletzt bearbeitet von einem Moderator:
Bearbeitet von: xminister - Grund: Direkt/Vollzitat entfernt.
Ah okay der Fehler ist schonmal behoben , habe

android.webkit.WebViewClient
und
android.webkit.WebView nicht importiert ...

Dafür schonmal Vielen Dank.

Wenn ich jetzt versuche die App zu starten kommt :
 

Anhänge

  • Error.jpg
    Error.jpg
    37,1 KB · Aufrufe: 237
Irgendwo am Ende einer Zeile fehlt ein ";". Klick die Fehlermeldung mal an, dann öffnet sich im Android Studio ein Fenster der Klasse, und dort wird der Fehler markiert.
 
  • Danke
Reaktionen: Wurstboy
Okay schon mal vielen Dank für die ganze Hilfe , aber ein kleine Problem habe ich noch.
Und zwar funktioniert jetzt alles mit Android Studio und die App funktioniert auch.
Nur leider nicht ganz so wie ich es erwartet habe. Ich habe eine Website ( die er laden soll ), auf dieser Website sind
ADS,Surveys bzw Werbung. Stattdessen das er meine Website läd, habe ich wenn ich die App öffne ca 2 Sekunden lang einen weißen Bildschirm und dann öffnet die App eine andere Seite. ( Die von den Ads,Survey also von der Werbung auf meiner Website.)

Jetzt habe ich etwas im Internet gewurschtelt und habe folgendes gefunden :

Code:
    mWebView.setWebViewClient(new WebViewClient() {


        @Override
        public boolean shouldOverrideUrlLoading(WebView view, String url) {
           // Here put your code
              Log.d("My Webview", url);

           // return true; //Indicates WebView to NOT load the url;
              return false; //Allow WebView to load url
        }
    });

Mit diesem Code sollte es wohl klappen , das er auch wirklich www.google.de öffnet bzw ihn zwingt auf dieser Website zu bleiben bis der Nutzer manuell einen neuen Button betätigt und nicht schon beim starten der App auf www.google.de/1 geht.

Mein Problem ist nur... Wie füge ich diesen Code in meine FullscreenActivity ein ?

Code:
package appnation.testAPP;

import android.annotation.SuppressLint;
import android.support.v7.app.ActionBar;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.os.Handler;
import android.view.MotionEvent;
import android.view.View;
import android.webkit.WebViewClient;
import android.webkit.WebView;

/**
* An example full-screen activity that shows and hides the system UI (i.e.
* status bar and navigation/system bar) with user interaction.
*/
public class FullscreenActivity extends AppCompatActivity {
    /**
     * Whether or not the system UI should be auto-hidden after
     * {@link #AUTO_HIDE_DELAY_MILLIS} milliseconds.
     */
    private static final boolean AUTO_HIDE = true;

    /**
     * If {@link #AUTO_HIDE} is set, the number of milliseconds to wait after
     * user interaction before hiding the system UI.
     */
    private static final int AUTO_HIDE_DELAY_MILLIS = 3000;

    /**
     * Some older devices needs a small delay between UI widget updates
     * and a change of the status and navigation bar.
     */
    private static final int UI_ANIMATION_DELAY = 300;
    private final Handler mHideHandler = new Handler();
    private View mContentView;
    private final Runnable mHidePart2Runnable = new Runnable() {
        @SuppressLint("InlinedApi")
        @Override
        public void run() {
            // Delayed removal of status and navigation bar

            // Note that some of these constants are new as of API 16 (Jelly Bean)
            // and API 19 (KitKat). It is safe to use them, as they are inlined
            // at compile-time and do nothing on earlier devices.
            mContentView.setSystemUiVisibility(View.SYSTEM_UI_FLAG_LOW_PROFILE
                    | View.SYSTEM_UI_FLAG_FULLSCREEN
                    | View.SYSTEM_UI_FLAG_LAYOUT_STABLE
                    | View.SYSTEM_UI_FLAG_IMMERSIVE_STICKY
                    | View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION
                    | View.SYSTEM_UI_FLAG_HIDE_NAVIGATION);
        }
    };
    private View mControlsView;
    private final Runnable mShowPart2Runnable = new Runnable() {
        @Override
        public void run() {
            // Delayed display of UI elements
            ActionBar actionBar = getSupportActionBar();
            if (actionBar != null) {
                actionBar.show();
            }
            mControlsView.setVisibility(View.VISIBLE);
        }
    };
    private boolean mVisible;
    private final Runnable mHideRunnable = new Runnable() {
        @Override
        public void run() {
            hide();
        }
    };
    /**
     * Touch listener to use for in-layout UI controls to delay hiding the
     * system UI. This is to prevent the jarring behavior of controls going away
     * while interacting with activity UI.
     */
    private final View.OnTouchListener mDelayHideTouchListener = new View.OnTouchListener() {
        @Override
        public boolean onTouch(View view, MotionEvent motionEvent) {
            if (AUTO_HIDE) {
                delayedHide(AUTO_HIDE_DELAY_MILLIS);
            }
            return false;
        }
    };

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        setContentView(R.layout.activity_fullscreen);
        WebView view = (WebView) this.findViewById(R.id.webView);
        view.setWebViewClient(new WebViewClient());
        view.loadUrl("https://www.google.de");
        view.getSettings().setJavaScriptEnabled(true);


        mVisible = true;
        mControlsView = findViewById(R.id.fullscreen_content_controls);
        mContentView = findViewById(R.id.fullscreen_content);


        // Set up the user interaction to manually show or hide the system UI.
        mContentView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                toggle();
            }
        });

        // Upon interacting with UI controls, delay any scheduled hide()
        // operations to prevent the jarring behavior of controls going away
        // while interacting with the UI.

    }

    @Override
    protected void onPostCreate(Bundle savedInstanceState) {
        super.onPostCreate(savedInstanceState);

        // Trigger the initial hide() shortly after the activity has been
        // created, to briefly hint to the user that UI controls
        // are available.
        delayedHide(100);
    }

    private void toggle() {
        if (mVisible) {
            hide();
        } else {
            show();
        }
    }

    private void hide() {
        // Hide UI first
        ActionBar actionBar = getSupportActionBar();
        if (actionBar != null) {
            actionBar.hide();
        }
        mControlsView.setVisibility(View.GONE);
        mVisible = false;

        // Schedule a runnable to remove the status and navigation bar after a delay
        mHideHandler.removeCallbacks(mShowPart2Runnable);
        mHideHandler.postDelayed(mHidePart2Runnable, UI_ANIMATION_DELAY);
    }

    @SuppressLint("InlinedApi")
    private void show() {
        // Show the system bar
        mContentView.setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
                | View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION);
        mVisible = true;

        // Schedule a runnable to display UI elements after a delay
        mHideHandler.removeCallbacks(mHidePart2Runnable);
        mHideHandler.postDelayed(mShowPart2Runnable, UI_ANIMATION_DELAY);
    }

    /**
     * Schedules a call to hide() in [delay] milliseconds, canceling any
     * previously scheduled calls.
     */
    private void delayedHide(int delayMillis) {
        mHideHandler.removeCallbacks(mHideRunnable);
        mHideHandler.postDelayed(mHideRunnable, delayMillis);
    }
}


Edit : Oder liegt es eventuell daran das meine Website keine optimierte Smartphone Website ist und deswegen weiterleitet ? Also ich mein sowas wie wenn man mit dem Handy auf www.Bild.de geht... Dann fragt er dich ja auch ob du zur Mobile Version willst oder nicht und eventuell macht er das bei der App auch aber ohne zu fragen und für ihn ist das nächst möglichste halt die ADS,Survey Werbung und geht deswegen auf die Seite ?

Edit 2 : Macht ja aber keinen Sinn da er die Website ja in WebView anzeigt .. Ich bin so ratlos :(

Edit 3 : Ich habe mal versucht meine Website auf meinem Tablet mit dem ganz normalen Chrome Browser zu öffnen & siehe an , er macht genau das gleiche wie in der App ... Er überspringt meine Website und geht sofort auf die Seite von der Werbung ... KOMISCH ?
 
Zuletzt bearbeitet:
@Wurstboy

Die Weiterleitung auf eine "Mobile version" wird vom http server vorgenommen und dahinter befindet sich dann ein anderer Content.
Dies geschieht idR durch die Abfrage des Request und woher er kommt

Bsp : PHP Script
PHP - Check if the page run on Mobile or Desktop browser

Selbst bei einem einfachen GET schickt das Device infos
Bsp :
GET /single-chartsff HTTP/1.1
Host: 37.187.xx.xx:xxxxx
User-Agent: Dalvik/2.1.0 (Linux; U; Android 5.1; Lenovo TAB 2 A8-50L Build/LMY47D)
Accept-Encoding: gzip, deflate
Connection: close



Alternativ dazu kannst du deine Seite z.b mit JQuery-Mobile versehen, dann hast du Ruhe .

P.S eine reine "DesktopSeite" macht man heutzutage auch nicht mehr - geht meistens schief
 
Zuletzt bearbeitet:

Ähnliche Themen

5
Antworten
0
Aufrufe
1.177
586920
5
D
Antworten
23
Aufrufe
2.685
Data2006
D
SaniMatthias
Antworten
19
Aufrufe
1.009
swa00
swa00
Zurück
Oben Unten