スキップしてメイン コンテンツに移動

Zeroから始めるAndroid(アンドロイド) App(アプリ) 開発 - ブラウザを作る

開発はもうしたくなかったのに
また開発しなければなりませんでした。(泣)
とのことで忘れないように一々書いときます。
始める方にもご参考になりますように。

Android Studioは無料なのでダウンロードしてインストール!

初めてのプロジェクトを作成。
プロジェクトとドメインを合わせてパッケージ名が決まるので
domain = littleworld.net
project name = giipAgent-Android
にしてみました。

そうしたら
/app/manifests/AndroidManifest.xml

<manifest xmlns:android="http://schemas.android.com/apk/res/android"    package="net.littleworld.giipagent_android">

と書かれました!
バージョン管理が必要なのでその下に
android:versionCode="104"
android:versionName="0.1.5"

と書きました。
これは適当に数字をアップするとアプリをインストールする際に勝手に上書きするので便利だし、後でバージョン管理およびアップデートに使われるので重要です!

これからWebViewを作るのでINTERNETという機能を使うのに権限をもらう必要があります。上記のバージョンを書いたその下にこれを入力

<uses-permission android:name="android.permission.INTERNET" />

androidからINTERNETを使いたいですよとのことです。
これで準備はOK!

Web画面を表示してみます。
新規プロジェクトを作成すると
MainActivity.java
content_main.xml
というファイルが自動で作成され、
画面に表示されます。

content_main.xmlファイルの下のタップを見るとDesignとTextと書いてるタップがあります。あそこでDesignタップ(最初このタップが表示されているはず)のPalleteからWidgetsを選択、するとその右にWebViewコンポーネントが見えます。
WebViewをドラックして画面に移動でこれはOK。

このファイルの下のタップからTextをクリックしてみます。
XMLデータが出てきますね。
あそこでWebViewと書いている領域に行って
次を追加

android:id="@+id/webView"

私の場合には項目を全て入れるのが面倒で

tools:ignore="MissingConstraints"

これも追加しました!

そして完成本は

<WebView    android:id="@+id/webView"    android:layout_width="368dp"    android:layout_height="231dp"    app:layout_constraintTop_toBottomOf="@+id/textView2"    tools:ignore="MissingConstraints"    tools:layout_editor_absoluteX="8dp" />

こんな感じ

このままでBuildしてAPKを作って見てもいいですが、白いボックスしか表示されないので次に行きましょう。

あのWebViewにスタートURLを入れてみましょう。
何かをプログラミングをするためにはjavaファイルをいじる必要があります。
MainActivity.javaをみてみましょう。

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

中程にonCreateというところがあるので
ここがアプリ開始するとき実行されるところです。

この下の適当な所にWebViewにURLを入れてみます。
setContentView(R.layout.activity_main);WebView webView = (WebView) findViewById(R.id.webView);webView.loadUrl("http://giipweb.littleworld.net");

もしHTMLデータを表示したかったら

setContentView(R.layout.activity_main);WebView webView = (WebView) findViewById(R.id.webView);//webView.loadUrl("http://giipweb.littleworld.net");String lwBody = "<html><body>Welcome giip world!!</body></html>";webView.loadData(lwBody, "text/html", null);

このように直接に表示してもいいです。

じゃ、終わったら
上段のBuildメニューからBuild APK(s)を選択。
すると、下に色々流れて終わったらメッセージが表示されます。

10:33   Build APK(s)
APK(s) generated successfully:
Module 'app': locate or analyze the APK.

メッセージのlocateをクリックするとAPKの場所が表示されます。

app-debug.apk

が見えるんでしょ。
そのファイル名を変えてみましょう。

giipAgent-0.1.5.apk

このように変更してみました。
これをGoogle Driveなどにアップして他のデバイスにインストールして実行すると完成です!

思ったより難しくないですが、これからですね!

コメント

このブログの人気の投稿

コピペができないときチェックすべきこと! :: よく迷うUiPathのコツ

UiPath( https://uipath.com )はMicrosoft社のWWFを改良した製品なのでVisual Studioより初心者向けに使いやすくなっている。 しかし、初心者がそのまま使うにはかなりのハドルがある。 理由は基本開発者向けの開発ツールを無理やり便利に作ってみたとしても開発の概念と考え方がないと結構躓くことが多い。 そのなかで私もよく迷ったりしていることの一つを整理しとく。 基本Activityはすぐコピぺができるので多数のUiPath Studioを開いて開発してたりする。 ここでコピペをしても反応ないときがよくある。 この場合はこれをチェックすること! 1.Sequenceがなく一つのActivityしかないところにはペーストできないのが多い。 例えば、ifの処理ボックスにはSequenceが最初はない。 そのボックスに一つのActivityはペーストできるのに2個目からはなぜか反応ない。 それで分からないまま新しいActivityを追加してたりしたが、 あそこにSequenceを入れたら解決ができるのだ! 2.正常にペーストできるはずのところに反応ない。 この場合はPackageが合わなくペーストが効かないケースが多い。 DESIGN>Manage Packagesをクリックしてコピー元のパッケージにインストールされているのにコピー先にインストールされてないパッケージを探す! パッケージを一々見るのが難しい!と思ったら メモ帳からファイルがあるフォルダにあるproject.jsonファイルを開いてみる! あそこにJSONの形式でインストールされたパッケージが見えるので比較しやすくなる! ちなみにコピペをすると変数の宣言が大変だと思うが、 そこでもコツがあるのだ! 変数の宣言はなるべく細かくしてSequence単位で管理できるようにする。 全てに影響がある変数はしょうがないから一番広く宣言するけど。 初心者向けの説明だと、 Variablesというところをクリックして変数を開いたらScopeという範囲が見える! 大体Sequenceボックスの名前を変えてないのでSequenceがすらりと表示されてるはずが、Sequenceボックスの名前を付けてたら見やすくなる。 あ...

英語をより楽に勉強できる方法

英語ができなくて良い機会が失われた経験があるでしょう。 GoogleさんもMicrosoftさんも英語で面接をしてます。 私がエンジニアですが技術より言語の学びが優先だと思います。 知り合いの中で技術は低いが英語が上手い人が私より良い道を歩いてます。 それは会話ができなければ技術も通じないとのことでしょう。 それで色々お試ししましたところ 情報を公開しようとしてます! まず、 Khan Academy( https://www.khanacademy.org/ )に入会! これはSalman Khanという人が自分の親戚に数学を教えるために試したやり方が色んな人が参加してグーグルさんとマイクロソフトさんが投資をした 完全無料教育サービス です。 しかし、これは英語でしか話してないので初心者の方には無理があるでしょう。 それでも、この記事をお読みになられた方は基本的な文法は学んだ方だと考えときます。 そして TEDアプリ( https://www.ted.com/ ) をダウンロード。 日本語の字幕がある映像の中で自分の好みの映像を選んでください。 有名なスピーカが話したことが多いので話し方など良い勉強になります。 次は MeetUp( https://www.meetup.com/ja-JP/ ) でしょ。 英会話グループを探して加入。 自分のレベルに合わせて参加してら良い友達もできるし勉強にもなります。 電車で単語ばっかり暗記している方が見つかりますが、 それも悪くは無いけど効率はどうかと思います。 やはり勉強は楽しく!自分の好みでは無いと! 映画も良いしドラマも良いです。それともゲームとか旅行もあるでしょう。 自分の趣味から始めるのが大切だと思います。 もしドロンが趣味だとしたらわざわざググってみる。 そして英語のページから探すんです。 最初は無理があるけど好きなイメージなどが見つかったら読みたいでしょ? そのページをスクリーンショットかプリントでも良いです。 その文書の単語を探して読んでみるのが第一歩ですね。 最初は辛いでしょ。 私の場合には最初には単語10個だけ探しました。 1日10個だけ辞書から探して残りは捨てる。 さらに10個をその場で暗記してそれで終わり。 翌日3~4個し...

UiPath - Excelのシート名が存在した場合の処理

UiPath.Excel Activityは活用方法によってかなり強力ですが、隠れて探せない項目が多すぎて困ったりします。 公式ドキュメントもいまいちだし…。 Excelを自動化するには協力なUiPathの機能の中でSheetの判断処理を残します。 今まではシートがあったら何とかしようとしたら見つける方法が分からなく、ErrorのExceptionで判断したりしましたが、 workbook.GetSheets.Contains("<sheet name>") があったのをいまさら見つけました; 早速試してみましたが、 messageboxにworkbookとか書いてみても出てこない…。 これはExcel Application Scopeを利用しなければなりませんでした! まずExcel Application ScopeにExcelファイルを登録! Excel Application Scope Activityの属性にOutputにwbを入力して変数に入れます。 変数に入れてからMessageBoxに wb.GetSheet.Contains("Sheet1") を入力してみると成功! 「wb.」をおした時点でいっぱい出てきましたね。 ググってみても詳しく出て着なかったのでここにまず記録 giip - Free UiPath and Rpa Integrated Orchestration Service https://giipasp.azurewebsites.net