質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.49%

  • Java

    14055questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

  • Android Studio

    3777questions

    Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

AndroidStudioのSpinnerとDatabaseについて

受付中

回答 0

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 158

hatch0808

score 2

AndroidStudioで地図アプリを作っているのですが、情報の表示を切り替えられるようにスピナーを用意し、スピナーで切り替えてボタンを押すとデータベースに保存してある情報がマップに表示されるもの作ろうと思っていたのですがスピナーでの切り替え方がよくわからないです。
さらに、ちゃんとデータベースをAndroidStudio内で作ったのですが全く表示されないです。
なので、スピナーでの切り替え方とマップ上にデータベースに保存した情報を表示させるやり方を教えてほしいです。
文章力がないので文章がまとまってないですがよろしくお願いしますm(_ _)m
あと初めて間もないのでコードは汚いです。

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Button btnStart = (Button) findViewById(R.id.btnMapStart);
        btnStart.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View v) {

                Intent intent = new Intent(getApplication(), MapsActivity.class);
                startActivity(intent);
            }
        });
    }
}
public class MapsActivity extends FragmentActivity implements OnMapReadyCallback {

    private GoogleMap mMap;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_maps);
        // Obtain the SupportMapFragment and get notified when the map is ready to be used.
        SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager()
                .findFragmentById(R.id.map);
        mapFragment.getMapAsync(this);
    }


    /**
     * Manipulates the map once available.
     * This callback is triggered when the map is ready to be used.
     * This is where we can add markers or lines, add listeners or move the camera. In this case,
     * we just add a marker near Sydney, Australia.
     * If Google Play services is not installed on the device, the user will be prompted to install
     * it inside the SupportMapFragment. This method will only be triggered once the user has
     * installed Google Play services and returned to the app.
     */
    @Override
    public void onMapReady(GoogleMap googleMap) {
        mMap = googleMap;

        // Add a marker in Sydney and move the camera
        //LatLng sydney = new LatLng(-34, 151);
        //mMap.addMarker(new MarkerOptions().position(sydney).title("Marker in Sydney"));
        //mMap.moveCamera(CameraUpdateFactory.newLatLng(sydney));

        mapInit();
    }

    private void mapInit() {

        // GoogleMapの初期設定
        mMap.setMapType(GoogleMap.MAP_TYPE_NORMAL);

        // 初期表示位置の指定
        LatLng location = new LatLng(35.690921, 139.700258);  // 新宿にする
        CameraPosition camerapos = new CameraPosition.Builder().target(location).zoom(15.5f).build();
        mMap.moveCamera(CameraUpdateFactory.newCameraPosition(camerapos));

        // UI セッティング
        UiSettings ui = mMap.getUiSettings();
        ui.setCompassEnabled(false);
        ui.setRotateGesturesEnabled(false);
        ui.setScrollGesturesEnabled(true);
        ui.setTiltGesturesEnabled(false);
        ui.setZoomControlsEnabled(false);
        ui.setZoomGesturesEnabled(true);

        markersSet();

    }

    private void markersSet() {

        // マーカーの設定
        MarkerOptions options = new MarkerOptions();
        options.draggable(false);
        ArrayList<ShopInfo> list = getShopInfoes();
        for( ShopInfo tmp : list) {
            options.position(tmp.getPosition());
            options.title(tmp.getName());
            options.snippet(tmp.getInformation());

            mMap.addMarker(options);
        }

    }

    private ArrayList<ShopInfo> getShopInfoes() {

        /*
        ArrayList<ShopInfo> ary = new ArrayList<ShopInfo>();

        ShopInfo tmp1 = new ShopInfo();
        tmp1.setPosition(new LatLng(35.696346, 139.698336));
        tmp1.setName("ラーメン二郎");
        tmp1.setInformation("こってこてのラーメン。完食は難しい!(7/14)");
        ary.add(tmp1);

        ShopInfo tmp2 = new ShopInfo();
        tmp2.setPosition(new LatLng(35.6990042, 139.6968819));
        tmp2.setName("もちもちの木");
        tmp2.setInformation("スープがあっつい!(7/8)");
        ary.add(tmp2);

        ShopInfo tmp3 = new ShopInfo();
        tmp3.setPosition(new LatLng(35.696594, 139.696601));
        tmp3.setName("麺屋 翔 本店");
        tmp3.setInformation("美味しい塩味ラーメンを味わえる!!!");
        ary.add(tmp3);
        */

        ShopInfoSQLiteOpenHelper helper = new ShopInfoSQLiteOpenHelper(this);
        ArrayList<ShopInfo> ary = helper.findAll();
        return ary;
    }
}
public class ShopInfo {

    public int getCategory() {
        return category;
    }

    public void setCategory(int category) {
        this.category = category;
    }

    public String getInformation() {
        return information;
    }

    public void setInformation(String information) {
        this.information = information;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public LatLng getPosition() {
        return position;
    }

    public void setPosition(LatLng position) {
        this.position = position;
    }

    public int getStar() {
        return star;
    }

    public void setStar(int star) {
        this.star = star;
    }

    private int category;          // お店のカテゴリ
    private String name;           // お店の名前
    private LatLng position;       // お店の場所情報
    private String information;    // 情報
    private int star;
}
public class ShopInfoSQLiteOpenHelper extends SQLiteOpenHelper {
    public ShopInfoSQLiteOpenHelper(Context context) {
        super(context, "RECOM_DB", null, 1);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL("CREATE TABLE SHOPINFO"
                + "(_id INTEGER PRIMARY KEY autoincrement, name TEXT, information TEXT,"
                + "star INTEGER, lat REAL, lng REAL, category INTEGER)");

        db.execSQL("INSERT INTO SHOPINFO VALUES (1, 'ラーメン二郎(Test)'', 'こってこてのラーメン。完食は難しい!', 3, 35.696346, 139.698336, 1)");
        db.execSQL("INSERT INTO SHOPINFO VALUES (2, 'もちもちの木(Test)', 'スープがあっつい!', 4, 35.6990042, 139.6968819, 1)");
        db.execSQL("INSERT INTO SHOPINFO VALUES (3, 'サイゼリア(Test)', '手軽にドリア!', 3, 35.697401, 139.6973857, 2)");
        db.execSQL("INSERT INTO SHOPINFO VALUES (4, '麺屋 翔 本店(Test)', '美味しい塩味ラーメンを味わえる!!!', 3, 35.696594, 139.696601, 1)");
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

    }


    // 全てのデータを検索
    public ArrayList<ShopInfo> findAll() {
        ArrayList<ShopInfo> ary = new ArrayList<ShopInfo>();
        SQLiteDatabase database = getReadableDatabase();
        if ( database == null ) {
            try {
                Cursor cur = database.query("SHOPINFO",
                        new String[]{"name", "information", "lat", "lng"}, null, null, null, null, null);
                while (cur.moveToNext()) {
                    ShopInfo tmp = new ShopInfo();
                    tmp.setName(cur.getString(0));
                    tmp.setInformation(cur.getString(1));
                    double lat = cur.getDouble(2);
                    double lng = cur.getDouble(3);
                    tmp.setPosition(new LatLng(lat, lng));
                    ary.add(tmp);

                }

            } finally {
                database.close();
            }
        }
        return ary;
    }

    // ファミレスだけを検索
    public ArrayList<ShopInfo>findByCategory(int kind) {
        ArrayList<ShopInfo> ary = new ArrayList<ShopInfo>();
        SQLiteDatabase database = getReadableDatabase();
        if ( database == null) {
            try {
                String kindStr = String.valueOf(kind);
                Cursor cur = database.query("SHOPINFO",
                        new String[]{"name", "information", "lat", "lng"},
                        "category=?", new String[]{kindStr}, null, null, null);
                while ( cur.moveToNext()) {
                    ShopInfo tmp = new ShopInfo();
                    tmp.setName(cur.getString(0));
                    tmp.setInformation(cur.getString(1));
                    double lat = cur.getDouble(2);
                    double lng = cur.getDouble(3);
                    tmp.setPosition(new LatLng(lat, lng));
                }
            } finally {
                database.close();
            }
        }
        return ary;
    }
}
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

まだ回答がついていません

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.49%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • Java

    14055questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

  • Android Studio

    3777questions

    Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。