Android AppにGPS機能実装の例

画面遷移

o2o-app
o2o-app

画面遷移するためのソースサンプル

1、遷移元画面 Listview.java

import com.soarcloud.O2O.Browser;
findButton.setOnClickListener(new View.OnClickListener() {  
  public void onClick(View v) { 
    Intent in = new Intent(getApplicationContext(), Browser.class);
    startActivity(in);	
  }  
});

2、遷移先のブラウザ画面 Brower.jaza

public class Browser extends Activity implements LocationListener {
	private WebView webView;// Create WebView object
	private Location mostRecentLocation;// Create Location object
	private LocationManager locationManager;// Create LocationManager object
	
   /** Called when the activity is first created. */
   @Override
   public void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.browser);
      getLocation();// Get the current geocoordinates
      openBrowser();// Open a browser with the Google MapView  
   } // end main activity method
   
   /** Called when Activity Resumes **/
   protected void onResume() {
	   super.onResume();
	   getLocation();
   } // end onResume method
   
   /** Called when Activity is Paused **/
   protected void onPause() {
	   super.onPause();
	   locationManager.removeUpdates(this);
   } // end onPause method
   
   /** Create webView and JavaScript Interface **/
   private void openBrowser(){
	  // Create webView and assign to web_view item
 	  webView = (WebView) findViewById(R.id.web_view);
 	  // JavaScript is off by default, enabling JavaScript
 	  webView.getSettings().setJavaScriptEnabled(true);
 	  // Enable zoom controls if supported by hardware
 	  webView.getSettings().setBuiltInZoomControls(true);
 	  // Create and set WebViewClient subclass for rendering
 	  webView.setWebViewClient(new WebViewClient());		
 	  // Add Java to JavaScript Interface and call it 'android' for access.
 	  webView.addJavascriptInterface(new JavaScriptInterface(), "android");
 	  // Wait for the page to load then send the location information
 	  webView.setWebViewClient(new WebViewClient()); 
 	  // Load map.html page with webView
 	  webView.loadUrl(getURL());							
   } // end Browser method
   
   // Method to set/return URL for map page source
   private String getURL() {
      final String url = "file:///android_asset/map.html";
	  return url;
	} // end getURL method

   /** Retrieve current coordinates from GPS
    *  To save battery on the device the location update time has been increased. **/
   private void getLocation() {
	    // Android GPS Manager
	     locationManager =
	      (LocationManager)getSystemService(Context.LOCATION_SERVICE);
	    // Application criteria for selection location provider
	    Criteria criteria = new Criteria();	
	    // Set the accuracy requirement
	    criteria.setAccuracy(Criteria.ACCURACY_FINE);
	    // Get location data from best source
	    String provider = locationManager.getBestProvider(criteria,true);
	    // Get updates of current location
	    locationManager.requestLocationUpdates(provider, 2000, 1, this);
	    // Pass location data mostRecentLocation for JavaScript Interface
	    mostRecentLocation = locationManager.getLastKnownLocation(provider);
   } // end getLocation method
   /** Required methods when using LocationListener 
    *  Referenced from Android API		**/ 
   @Override
   public void onProviderDisabled(String provider) {
   }
   @Override
   public void onProviderEnabled(String provider) {
   }
   @Override
   public void onStatusChanged(String provider, int status, Bundle extras) {
   }
   @Override
   public void onLocationChanged(Location location) {
	   mostRecentLocation = location;
   }
   /** End required methods when using LocationListener **/   
} // End Browser.class Activity

3、AndroidManifest.xmlにBrowser画面を追加

<activity android:name="com.soarcloud.O2O.Browser" android:screenOrientation="portrait" />

4、Google地図を表示するmap.htmlを追加

<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no" />
<meta http-equiv="content-type" content="text/html; charset=UTF-8"/>
<title>Google Map</title>
<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false"></script>
<script type="text/javascript">
function initialize() {
	var myOptions = {
		zoom: 17,
		mapTypeId: google.maps.MapTypeId.HYBRID
	}
	var map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
	var position_options = {
		enableHighAccuracy: false
	};
	navigator.geolocation.watchPosition(function(position) {
		var myLatlng = new google.maps.LatLng(position.coords.latitude, position.coords.longitude);
		map.setCenter(myLatlng);
		var marker = new google.maps.Marker({
			position: myLatlng,
			map: map
		});
	}, null, position_options);
}
</script>
<style type="text/css">
html, body {
	height: 100%;
	margin: 0;
	padding: 0;
	}
#map_canvas {
	height: 100%;
	}
</style>
</head>
<body onload="initialize()">
<div id="map_canvas"></div>
</body>
</html>
0

ロボット・ドローン部品お探しなら、ロボット翔をご利用下さい

Fluentedを使ってセンサデータの収集、クラウドへ転送

サーバ側Fluented設定

## built-in TCP input
## $ echo <json> | fluent-cat <tag>
<source>
 type forward
 port 24224
</source>
<match sensor.test>
 type mongo
 database sensor
 collection test
 host localhost
 port 27017
 disable_collection_check true
 capped
 capped_size 2048m
</match>
<match gyro.test>
 type mongo
 database gyro
 collection test
 host localhost
 port 27017
 disable_collection_check true
 capped
 capped_size 2048m
</match>

センサデータ収集転送側Fluentd設定

coming soon

ロボット翔-電子部品ストアで、SLAM LIDARなどのロボット部品、ドローン、センサモジュールを販売しています。

0

ロボット・ドローン部品お探しなら、ロボット翔をご利用下さい

WordPressでサイト構築に最も基本的plugin、ツール等

 

プラグイン新規追加画面でプラグインを検索してインストールを行えます。

1、SEO用タグtitle、description、descriptionをページ毎設定できます。ページ一覧でも変更可能に。
All In One SEO Pack
2、捜索エンジン用xmlファイルを自動的に作成してくれます。
Google XML Sitemaps
3、テーブルを入力だけで作れます。ただセルの幅設定はできないようです。
TablePress
4、可愛いアイコンフォント、ショートコード をテキストに埋め込めば設置完了します。
Font Awesome Icons
5、ページのレイアウトを思うとおりに作れます。Page Builder by SiteOrigin
6、ショートコードでサイトマップの固定ページ作成してくれます。PS Auto Sitemap
7、ページの表示位置をトップまでジャンプさせます。Royal Scroll to Top
8、ファビコンを表示させます。Favicon XT-Manager

 

ソースコードを編集できるフリーIDEツール

9、NetbeansはFTP機能付きで、サクサク動きます。ソースコードを編集できるプラグインもありますが、ただ変数など検索できません。NetbeansとXamppでローカル疑似サーバ環境も作れます。開発に最適です。MACにはCODAが定番でしょう。

 

セキュリティ考慮

10、Admin画面へログインの試みを防ぐには、Basic認証を追加したほうが簡単です。.htaccess .passwdファイルを作ってサイトへ配置しておきます。

 

投稿した内容を一括編集できるプラグイン

11、Search Regex、wordpress4.2では動作していますが、以降のバージョンはデータベースをバックアップして使用するのをすすめます。当方はこのプラグインを利用して、すべての投稿の


へ切り替えました。さきにsearchして、searchの結果を見てかたまたreplace、saveしていきましょう。とても
便利なツールで感動しました。

 

データベースなどまとめてバックアップと取ってくれるプラグイン

12、BackWPup

 

画像、色合い

13、photoshop、Adobe kuler、pltts.meを組み合わせて、画像、色いを決めます。

 

CSS作成支援

14、Compass、Sass、HAML等プログラミングらしくCSSを作れます。

0

ロボット・ドローン部品お探しなら、ロボット翔をご利用下さい