Language
ログイン
言語設定
X
English
日本語 [Japanese]
オープンデータを使ってアプリを作ろう
アプリケーションの作成と公開をサポートするサイト
お問い合わせ
HOME
チュートリアル
アプリ新規作成
アプリのFork
公開アプリ一覧
アプリ作品の情報
JAXA
衛星
気候
NASA
agriculture
farmland
climate
satellite
農業
Faamo 〜あなたにピッタリな農地探しをお手伝い〜
fullscreen
たく
International Space Apps Challenge Tokyo 2014にて第3位を獲得しました!
Faamo: FArm-Activating Market OptimizerはJAXA衛星データを用いた農地のクラスタリングにより、ユーザーの指定した産地に似た環境の農地を探し、海外の生産拠点探しを支援するアプリケーションです。 また、各地の人口増減傾向や物価などの情報も示し、進出先の市場性も合わせて評価することが可能です。 将来的には、同様の環境下で農業を営む生産者の間でノウハウを共有できるコミュニティ作りにつなげることも想定しています。
詳細はこちら→
http://prezi.com/cufyh6q5b8ky/faamo/
7
評価指数
いいね!
5
Loading...
このアプリ作品で使われているデータと同じ形式のデータを作成し、このアプリに適用することができます。
ひな形として使うファイルをリストから選択し、"Create Templete"をクリックして下さい。
アプリケーション
fullscreen
play
stop
reload
Play
JavaScript
CSS
HTML
概要
保存した実行結果
Faamo 〜あなたにピッタリな農地探しをお手伝い〜
jquery-1.7.1.min.js
https://www.google.com/jsapi
http://maps.googleapis.com/maps/api/js?sensor=false&v=3&language=ja&libraries=visualization
Faamo 〜あなたにピッタリな農地探しをお手伝い〜
Faamo 〜あなたにピッタリな農地探しをお手伝い〜
Faamo 〜あなたにピッタリな農地探しをお手伝い〜
Faamo 〜あなたにピッタリな農地探しをお手伝い〜
if(typeof Application==="undefined"||!Application){var Application = {};} // map var map = null; // var cityMasterArray = null; var cityMarketArray = null; var cityObservationArray = null; // アプリケーションのビジネスロジック Application.faamo = function(){this.init();}; // faamoメイン Application.faamo.prototype = { // 初期化処理 init : function(){ this._loadStart(); var isSuccess = this._loadData(); if(!isSuccess){ this._loadError(); } else { this._loadEnd(); } }, // ロード時のローディング画面 _loadStart : function(){ console.log('now loading'); $('#main_contents').hide(); }, _loadEnd : function(){ $("#loading").delay(600).fadeOut(700); $('#main_contents').show(); console.log('load success'); }, _loadError : function(){ alert('load error'); }, // データロード _loadData : function(){ var application = new Application.faamo.LinkData(); // // if(this.isEmpty(cityMaster)){ cityMasterArray = application.getDataResult('city_master'); // } // // if(this.isEmpty(cityMarket)){ cityMarketArray = application.getDataResult('city_market'); // } // // if(this.isEmpty(cityObservation)){ cityObservationArray = application.getDataResult('city_observation'); // } return true; }, }; // LinkData関連 Application.faamo.LinkData = function(){}; Application.faamo.LinkData.prototype = { /** * 指定ファイル内のデータを取得 * @param dataname 取得するデータソースのファイル名 * @result データソースファイル内の全データの配列 */ getDataResult : function(dataname){ var resultArray = null; $.each(LinkData.getWorks(), function(wKey, workId){ $.each(LinkData.getFiles(workId), function(fKey, filename){ if(filename == dataname){ $.each(LinkData.getSubjects(workId, filename), function(sKey, subject){ if(resultArray == null) resultArray = new Array(); var objArray = []; $.each(LinkData.getProperties(workId, filename), function(pKey, property){ var obj = LinkData.getObjects(workId, filename, subject, property); var prop = property.split('#')[1]; var data = obj[0]; if(data == '' || data == 'undefined') data = '-'; objArray[prop] = data; }); resultArray.push(objArray); }); } }); }); return resultArray; } }; Application.faamo.Draw = function(){this._init();}; Application.faamo.Draw.prototype = { _init : function(){ }, drawMap : function(){ var latlng = new google.maps.LatLng(39, 138); var opts = { zoom: 2, mapTypeId: google.maps.MapTypeId.SATELLITE, center: latlng }; map = new google.maps.Map(document.getElementById("map"), opts); for(var i = 0; i < cityMasterArray.length; i++){ var cityData = cityMasterArray[i]; var markerOpt = new google.maps.Marker({ position: new google.maps.LatLng(cityData.lat, cityData.long), map: map, icon: 'http://labs.google.com/ridefinder/images/mm_20_red.png' }); this._plotMarker(markerOpt, cityData); } }, _plotMarker : function(markerOpt, cityData){ var marker = new google.maps.Marker(markerOpt); var instance = this; google.maps.event.addListener(marker, 'click', function(event){ // popup表示 instance._showInfoWindow(markerOpt, cityData); // グラフの表示 instance._drowChart(cityData); // クリックしたマーカーのクラスを作る var heatmapData = new Array(); var cityCluster = cityData.cluster; cityMasterArray.forEach(function(cityMaster, idx){ // console.log(cityMaster.cluster + ' == ' + cityCluster); if(cityMaster.cluster == cityCluster){ // console.log(' -> match!!!!!'); // heatmap表示 heatmapData.push(new google.maps.LatLng(cityMaster.lat, cityMaster.long)); } }); var heatmap = new google.maps.visualization.HeatmapLayer({ data: heatmapData, radius:25 }); heatmap.setMap(map); }); marker.setMap(map); }, _openInfoWindow : null, _showInfoWindow : function(marker, cityData){ console.log('openwindow: ' + this._openInfoWindow); if (this._openInfoWindow) { this._openInfoWindow.close(); } this._openInfoWindow = new google.maps.InfoWindow({ content: this._buildHtmlMarketData(cityData) }); google.maps.event.addListener(this._openInfoWindow,'closeclick',function(){ this._openInfoWindow = null; }); this._openInfoWindow.open(marker.getMap(), marker); }, _buildHtmlMarketData : function(cityData){ var html = ''; var marketData = null; cityMarketArray.forEach(function(cityMarket, idx){ if(cityData.label == cityMarket.label){ marketData = cityMarket; return; } }); if(marketData == null) return null; html = cityData.city_name + ' (' + cityData.country_name + ')<br />' + '人口増加予測: ' + marketData.population_2013 + ' (2013年) → ' + marketData.population_2030 + ' (2030年予測)<br />' + // '物価: ' + '米: $ ' + marketData.price_rice + ' (/1Kg)<br />' + 'オレンジ: $ ' + marketData.price_orange + ' (/1Kg)<br />' + 'レタス: $ ' + marketData.price_lettuce + ' (/1玉)<br />' + '主要品目: ' + marketData.crop_rank1 + ', ' + marketData.crop_rank2 + ', ' + marketData.crop_rank3 + ', ' + marketData.crop_rank4 + ', ' + marketData.crop_rank5 + ','; return html; }, _drowChart : function(cityData){ var parentNode = document.getElementById('charts'); $('#charts').empty(); var dataType = new Array(); dataType[0] = {type: 'ndvi', str: 'Normalized Difference Vegetation Index: 植生分布密度指標'}; dataType[1] = {type: 'olst', str: 'Land Surface Temperature: 地表面温度 (K)'}; dataType[2] = {type: 'par', str: 'Photosynthetically Available Radiation: 光合成有機放射量 (Einstein/m2/day)'}; dataType[3] = {type: 'smc', str: 'Soil Water Content: 土壌水分量 (%)'}; for(var i = 0; i < dataType.length; i++){ var dataArray = this._createDataArray(cityData.label, dataType[i].type); var sourceData = [['月', dataType[i].str]].concat(dataArray); console.log('dataArray: ' + sourceData); var options = { lineWidth: 5, colors: ['#71BE6B'], legend: {position:'none'}, title: dataType[i].str }; var childNode = document.createElement('div'); childNode.setAttribute('id', dataType[i].type); parentNode.appendChild(childNode); var chart = new google.visualization.LineChart(childNode); chart.draw(google.visualization.arrayToDataTable(sourceData), options); } }, _createDataArray : function(cityCode, dataType){ var dataArray = null; cityObservationArray.forEach(function(obs, idx){ if(dataArray == null) dataArray = new Array(); if(cityCode == obs.City_ID){ var data = 0; if(dataType == 'ndvi') data = obs.ndvi; if(dataType == 'olst') data = obs.olst; if(dataType == 'par') data = obs.par; if(dataType == 'smc') data = obs.smc; dataArray.push([parseInt(obs.month), parseFloat(data)]); } }); return dataArray; } }; google.load("visualization", "1", {packages:["corechart"]}); var application = new Application.faamo(); var draw = new Application.faamo.Draw(); google.setOnLoadCallback(draw.drawMap());
/* global */ #container { background: #FFF; padding: 10px; font-size: 14px; font-family: "ヒラギノ丸ゴ ProN","Hiragino Maru Gothic ProN", Meiryo; // min-width: 980px; } /* top */ #title { /* margin: 10px 0;*/ text-align : center; } #title #logo-img { /* float: left;*/ width: 70px; /* margin-right: 10px; */ text-align : center; } #title #logo { width: 240px; } #title h3 { color: #71BE6B; font-size: 1.1em; margin: 0; font-weight: normal; letter-spacing: 0.1em; } /* application */ #application { text-align: center; } #map { // min-width: 700px; // max-width: 1000px; width: 100%; height: 450px; } #charts { text-align: center; }
<div id="container"> <div id="title"> <img id="logo-img" src="http://app.linkdata.org/asset/103a7396.png" /> <img id="logo" src="http://app.linkdata.org/asset/d021b18e.png"/> <h3>あなたにピッタリな農地探しをお手伝い</h3> </div> <div id="application"> <div id="loading"> <img src="http://app.linkdata.org/asset/e1c6626d.png"/> </div> <div id="main_contents"> <div id="map">map</div> <div id="charts"></div> </div> </div> </div>
jquery-1.7.1.min.js
https://www.google.com/jsapi
http://maps.googleapis.com/maps/api/js?sensor=false&v=3&language=ja&libraries=visualization
このアプリをForkして新しいアプリを作る
ダウンロード
Fork元のアプリは更新されました.
>>see
アプリは更新されました.
>>see
ツイート
このアプリ作品をwebから探す
作者
メッセージ送信
たく
共同編集者
Sayoko Shimoyama
Yuta Aoki
Akihiro_Ishimura
いき
Takeshi OSOEKAWA
Fork元のアプリ
たく
's
グローバル都市マッチングシステム
実行回数
1033
ウェブサイト
ライセンス
http://opensource.org/licenses/BSD-2-Clause
Fork count
1
作成日
2014年3月30日
最終更新日
2014年4月18日
Fork元のアプリ
グローバル都市マッチングシステム
作者: たく
更新日: 2014年4月19日
914 回実行
Forkして作られたアプリ
forked:faamo
作者: たく
更新日: 2014年4月13日
226 回実行
"
" コミュニティへの投稿が完了しました。投稿したアプリ作品は、コミュニティ管理者によって承認されるとコミュニティに公開されます。
エントリー先のコミュニティとカテゴリ名を選択し、「エントリー」ボタンをクリックして下さい。
チュートリアル
アプリ作品の削除をする場合は削除をクリックしてください
送信者
名前
*
E-mail
*
件名
*
メッセージ
*
アクセス認証
*
送信
キャンセル
入力データ
関連アイデア
このアプリ作品で入力データとして使われているデータ作品のリストです。
チェックボックスの選択を変更すると、入力データを変更して実行することができます。
Faamo
作者: Sayoko Shimoyama
更新日: 2014年4月13日
1102 ダウンロード
,
3 アプリケーション
city_market
city_master
city_observation
自分のデータを入力する
このアプリを使ったアイデアはまだ公開されていません
アイデアを作成
ニュースフィード
linkdata.org に関するツイート