Android Vibrator サンプル

android_vibrate

https://github.com/pppiroto/KaigiUtil/tree/8dd1ca93ff33afa73714eeaafedbd71ef052a52c

Fragment から Vibratorを起動する。

1.レイアウト

バイブレーター開始ボタン、終了ボタンを配置

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="info.typea.kaigiutil.SleepDefenderFragment">


    <LinearLayout
        android:orientation="horizontal"
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <Button
            android:id="@+id/btn_vib_start"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="START" />

        <Button
            android:id="@+id/btn_vib_stop"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="STOP" />

    </LinearLayout>
</FrameLayout>

2.バイブレーターを開始/停止する

HTC Desire 626 で動作確認をしていのたがうんともすんとも言わない。設定もおかしくなさそうだし、ググっても不具合的な情報もないし、、、

と、30分くらい途方に暮れていたら、省電力モードだと、バイブレーション機能がOFFになるようだ。省電力モードを切ったら動きました。

package info.typea.kaigiutil;

import android.content.Context;
import android.os.Bundle;
import android.os.Vibrator;
import android.support.annotation.Nullable;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Toast;


public class SleepDefenderFragment extends Fragment implements View.OnClickListener {
    private static final String ARG_MSG = "message";
    private Vibrator vibrator;

    public SleepDefenderFragment() {
    }

    public static SleepDefenderFragment newInstance(String message) {
        SleepDefenderFragment fragment = new SleepDefenderFragment();
        Bundle args = new Bundle();
        args.putString(ARG_MSG, message);
        fragment.setArguments(args);
        return fragment;
    }

    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        super.onCreateView(inflater, container, savedInstanceState);
        return inflater.inflate(R.layout.fragment_sleep_defender, container, false);
    }

    @Override
    public void onViewCreated(View view, @Nullable Bundle savedInstanceState) {
        super.onViewCreated(view, savedInstanceState);

        view.findViewById(R.id.btn_vib_start).setOnClickListener(this);
        view.findViewById(R.id.btn_vib_stop).setOnClickListener(this);

        vibrator = (Vibrator)this.getContext().getSystemService(Context.VIBRATOR_SERVICE);
    }

    @Override
    public void onClick(View v) {

        switch(v.getId()) {
            case R.id.btn_vib_start:

                if (!vibrator.hasVibrator()) {
                    Toast.makeText(this.getContext(), "no vibrator.", Toast.LENGTH_LONG).show();
                    return;
                }
                Toast.makeText(this.getContext(), "start vibe", Toast.LENGTH_SHORT).show();
                long pattern[] = {1000, 100 };
                int repeatIndex = 0; // 繰り返し開始位置 -1の場合繰り返しなし
                vibrator.vibrate(pattern, repeatIndex);
                break;

            case R.id.btn_vib_stop:

                vibrator.cancel();
                Toast.makeText(this.getContext(), "stop vibe", Toast.LENGTH_SHORT).show();
                break;
        }
    }
}

fragment_dynamic

静的に定義した、Fragment を動的に追加するよう、変更する。https://github.com/pppiroto/KaigiUtil/tree/92bb627ae2256e10008f17b501f022a75806c13c

1.Activity

Fragmentを配置するレイアウト

1.1 レイアウト

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="info.typea.kaigiutil.ContentActivity">

    <LinearLayout
        android:id="@+id/content_fragment_container"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="horizontal">
    </LinearLayout>

</android.support.constraint.ConstraintLayout>

1.2 Fragmentを読み込むActivity

package info.typea.kaigiutil;

import android.os.Bundle;
import android.support.v4.app.FragmentManager;
import android.support.v7.app.AppCompatActivity;

public class ContentActivity extends AppCompatActivity {

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

        FragmentManager fragmentManager = getSupportFragmentManager();
        fragmentManager.beginTransaction()
                .add(R.id.content_fragment_container,
                    SleepDefenderFragment.newInstance("test message"))
                .addToBackStack(null)
                .commit();
    }
}

2.呼び出されるFragment

2.1 レイアウト

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="info.typea.kaigiutil.SleepDefenderFragment">

    <TextView
        android:id="@+id/txt_message"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:text="TEST" />

</FrameLayout>

2.2 Fratment

package info.typea.kaigiutil;

import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;


public class SleepDefenderFragment extends Fragment {
    private static final String ARG_MSG = "message";

    public SleepDefenderFragment() {
    }

    public static SleepDefenderFragment newInstance(String message) {
        SleepDefenderFragment fragment = new SleepDefenderFragment();
        Bundle args = new Bundle();
        args.putString(ARG_MSG, message);
        fragment.setArguments(args);
        return fragment;
    }

    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        super.onCreateView(inflater, container, savedInstanceState);
        return inflater.inflate(R.layout.fragment_sleep_defender, container, false);
    }

    @Override
    public void onViewCreated(View view, @Nullable Bundle savedInstanceState) {
        super.onViewCreated(view, savedInstanceState);
        TextView txtMessage = (TextView)view.findViewById(R.id.txt_message);
        txtMessage.setText(getArguments().getString(ARG_MSG));
    }
}

android_grid_view02

Activity に 直接GridViewを配置したものを、Fragmentに切り出す。

1.Fragment用のレイアウト

Activity から、GridView部分を移動

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="info.typea.kaigiutil.MenuItemFragment">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="horizontal">
        <GridView
            android:id="@+id/grid_menu"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:numColumns="auto_fit"
            android:gravity="center">

        </GridView>
    </LinearLayout>

</FrameLayout>

2.Activityのレイアウトを修正

Fragmentをレイアウトファイルに静的に定義する、もともと、GridViewを定義していた場所をFragmentに置き換え

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="info.typea.kaigiutil.MainActivity">

    <fragment
        android:id="@+id/menu_item_fragment"
        android:name="info.typea.kaigiutil.MenuItemFragment"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>

</android.support.constraint.ConstraintLayout>

3.Fragmentの実装

GridViewのアイテムをクリックしたら、トーストを表示させる。

package info.typea.kaigiutil;

import android.content.Intent;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.GridView;
import android.widget.TextView;
import android.widget.Toast;

public class MenuItemFragment extends Fragment {
    public MenuItemFragment() {
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {

        View v = inflater.inflate(R.layout.fragment_menu_item, container, false);
        GridView gv = (GridView)v.findViewById(R.id.grid_menu);
        gv.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView parent, View view, int position, long id) {
                Toast.makeText(MenuItemFragment.this.getContext(),
                        ((TextView)view.findViewById(R.id.txt_menu_item)).getText(), Toast.LENGTH_LONG).show();
            }
        });

        return v;
    }

}

4.その他の個所

サンプルコードが最低限、コンパクトでいい感じ。最新SDK対応版がでるといいな