이런 에러가 발생 했을 경우.. 

to enable the nesting exclude '......./' from ~~~

 
pom.xml 에 아래 태그를 삭제한다.

<sourceDirectory>src</sourceDirectory> 

해결..
~/.subversion/auth/svn.simple/ 하위 파일을 모두 지운다.

'Server > Ubuntu' 카테고리의 다른 글

Jenkins 설치 및 구동하기 [임시]  (0) 2014.08.07
find  (0) 2014.05.21
SVN 인증 캐시 지우기.  (0) 2014.04.30
useradd , adduser  (0) 2013.10.06
Character Set 확인 및 변경  (0) 2013.08.08
make install  (0) 2013.07.16

(왜.. 자동 배포가 꺼져있는지 아리송... 매일 새벽에 자동배포 되게끔 되어 있는데.. 음... )



위/경도를 미리 설정하여 마커를 표시하는건 간단하다.

국가(또는 지역)의 정중앙에 마커를 표시하게 되면 따로 마커를 설정할 필요가 없어서 시도해보았다.

결과를 보면 절반의 성공이다....

위도 계산이 안맞다;; 경도는 어찌해서 맞추었는데 위도는 못맞추겠다..

그리고.. 이게 부질없다고 느끼게 한 나라는.. 프랑스(FR)이다

프랑스는 남아메리카에도 영토가 있다;; 
프랑스 정중앙에 마커를 표시하면 대서양에 마커가 찍힌다.. 

고로.. 그냥 마커로 표시하는게 좋을듯하다는게 결론...

국가코드에 KR, US, FR, CA, CN, RU, JP, AU 등등... 

Result


Style
 
body{
	font-size: medium;
}
.jvm-legend {
	line-height: 2em;
	margin-top: 5px;
}
.jvm-legend span {
	vertical-align: middle;
}
.jvm-legend-item {
	width: 2em;
	height: 2em;
	display: inline-block;
	border-style : solid;
	border-color : black;
	border-width : 1px; 
}

.jvm-legend-item-15 {
	background: red;
}
.jvm-legend-item-10 {
	background: orange;
}
.jvm-legend-item-5 {
	background: yellow;
}
.jvm-legend-item-0 {
	background: white;
}

table .td-legend{
	padding-left: 10px
} 

Source
 
var jMap = null;
function numberFormatComma(n) {
	var reg = /(^[+-]?\d+)(\d{3})/;   // 정규식
	n += '';                          // 숫자를 문자열로 변환
	while (reg.test(n)){
		n = n.replace(reg, '$1' + ',' + '$2');
	}
	return n;
}

var countryData = []; 
//for each country, set the code and value
$.each(data.countries, function() {
    countryData[this.code] = this.pGdp;
});

var markers = [ ];

$(document).ready(function(){
	// map
	jMap = $('#jvm_worldMap').vectorMap({
		map : 'world_mill_en',
		series : {
			regions : [ {
				values : countryData,
				scale : [ '#C8EEFF', '#0071A4' ],	// two colors: for minimum and maximum values 
				normalizeFunction : 'polynomial'
			} ]
			,
			markers: [{
	            attribute: 'fill',
	            scale: ['#1B77E0', '#E01B1B'],
	            min: 0,
	            max: 1
	        }]
		},
		//-----------------------------------------------
        // changed to onRegionLabelShow from onLabelShow
        //-----------------------------------------------
        onRegionLabelShow: function(e, el, code) {
            //search through data to find the selected country by it's code
            var country = $.grep(data.countries, function(obj, index) {
                return obj.code == code;
            })[0]; //snag the first one
            //only if selected country was found in dataC
            if (country != undefined) { 
                el.html(el.html() + 
                        "
Code: " +country.code + "
Name: " + country.name + "
GDP/Person: $ " + numberFormatComma(country.pGdp)+ "
Population: "+ numberFormatComma(Math.round(Number(country.pop)/10000))+" 만명"); } } ,markerStyle : { initial : { fill : '#F8E23B', stroke : '#383f47' } }, markers : markers }); $('#countryCode').bind({ keyup : function(e){ switch(e.which){ case 13: var code = e.target.value; var mapObj = jMap.vectorMap('get', 'mapObject'); if(mapObj.regions[code] != undefined){ var bbox = mapObj.regions[code].element.getBBox(); var scale = mapObj.scale; // var centroid = [ (bbox.x * scale) + (bbox.width * scale)/2 + mapObj.transX, (bbox.y * scale) + (bbox.height * scale)/2 + mapObj.transY ]; // var centroid = [ ((bbox.x + bbox.width) * scale)/2 + mapObj.transX, ((bbox.y + bbox.height) * scale)/2 + mapObj.transY ]; // var latLng = mapObj.pointToLatLng( (bbox.x * scale) + (bbox.width * scale)/2 + mapObj.transX, (bbox.y * scale) + (bbox.height * scale)/2 + mapObj.transY ); var zoomMax = (mapObj.params.zoomMax * mapObj.baseScale); var widthPerZoom = bbox.width / zoomMax; var heightPerZoom = bbox.height / zoomMax; var scaleWidth = (scale * widthPerZoom); var scaleHeight = (scale * heightPerZoom); var test = [bbox.x + bbox.width/2, bbox.y + bbox.height/2]; // console.log(test); var latLng = mapObj.pointToLatLng(test[0] * scale, test[1] * scale) // console.log(latLng); var mk = { latLng : [latLng.lat, latLng.lng], name : code, style: {r: 5} } mapObj.addMarkers([mk], []); mapObj.onResize(); }else{ alert('invalid code!!'); } break; } } }) });


HTML
	
국가코드 :


가능하면 쓰지 말자..

'WAS' 카테고리의 다른 글

Jeus에서 function tag libary 사용시...  (0) 2013.11.12
WebLogic 9.2  (0) 2012.12.13


var nodeName = '';
function makeXml(element, str) {
	$.each(element, function(key, sub){
		if( sub instanceof Object){
			if ( sub instanceof Array ){
				$.each(sub, function(idx, data){
					str += makeXml(data, '');
					str += '';
				});
			}
			else{
				nodeName = '<'+key+'>';
				str += makeXml(sub, nodeName);
				str += '';
			}
		}
		else{
			var value = sub;
			if(key == 'text'){
				str += (value==null)?'':value;
			}
		}
	});
	return str;
}


	var headerSet = {};
	headerSet.staticsticKind = {text:'복합기후요소'};
	headerSet.staticsticDate = {text:'년도별: 2010 ~ 2012년'};
	headerSet.stn = {text:'강릉(105), 대관령(100), 동해(106), 북강릉(104), 속초(90), 영월(121), 원주(114), 인제(211), 정선군(217), 철원(95), 춘천(101), 태백(216), 홍천(212)'};
	headerSet.staticsticEtcCondition = {text:''};
	headerSet.staticsticPrintColumn = {text:'평균기온,최고기온,최저기온'};
	$.each(chartUploadFilePath, function(idx, path){
		headerSet[staticsticChartPath+(idx+1)] = {text:path};
	});
	headerSet.lastTitleVal = {text:'복합요소 통계보고서'};
	headerSet.firstColumn = {text:'지점번호'};
	headerSet.secondColumn = {text:'요소'};

	var resultData = {};
	resultData.headerSet = headerSet;

	var source = {};
	source.resultData = resultData;
	var xml = '';
	var result = makeXml(source, xml);
	console.log(result);


v

'Web > 스크립트 일반' 카테고리의 다른 글

숫자 뒤 % 붙이기.  (0) 2017.11.30
숫자 외 몇몇 키 만 입력받기  (0) 2017.11.30
String to Date  (0) 2017.11.29
Object to XML  (0) 2013.11.07
자바스크립트 Array remove  (0) 2013.08.28

  • useradd : 순수 계정만 생성, 사용자 옵션에 따라 홈디렉토리 및 쉘을 설정해야만 한다.
  • adduser : 기본적인 정보를 입력받으며 계정을 생성하고, 홈디렉토리 생성 및 bash로 설정한다


자꾸 차이점이 기억이 안나기 시작한다.. ;;


useradd 주요 옵션..


  • -d : 홈디렉토리를 지정한 디렉토리로 생성
  • -m : /home/에 디렉토리 생성
  •  -s : shell 지정.
  • -c : 사용자에 대한 코멘트 입력 
대충 요정도.. 

 

'Server > Ubuntu' 카테고리의 다른 글

find  (0) 2014.05.21
SVN 인증 캐시 지우기.  (0) 2014.04.30
useradd , adduser  (0) 2013.10.06
Character Set 확인 및 변경  (0) 2013.08.08
make install  (0) 2013.07.16
SVN 다중 저장소  (0) 2013.06.13

Shape 파일을 열어서 해안선이 실측지도 처럼 나타나는 상황에서 jVectorMap으로 변환할 경우
IE8 이하에서 스크립트 엔진이 멈출 수 있다.


아래는 실측 해안선 일 경우 QGIS에서 확인한 폴리곤 포인트이다.  


위 처럼 포인트가 많을 경우 SVG로 변환할 Path도 많아지므로 VML로 그리다가 멈춘다.

이를 위해 포인트를 정리해주어야 하는데.. 

주위 GIS 개발자에게 물어본 결과 ArcGIS를 이용하여 단순화 할 수 있다고 한다.
그러나 너무 어렵다! 어디 들어가야하는지도 모르겠거니와... 방법도 모르겠고...


구글에서 찾다보니 아래 사이트가 있다.

mapshaper

 저 사이트가 날 살렸다.

웹상에서 슬라이더 조작만으로 포인트를 줄일 수 있다. 

아래처럼....



위 포인트는 눈으로 셀 수 있을만큼 줄어들었다.

실측 지도를 jVectorMap으로 변환하였을때는 17M
간략하게 만든 후 변환하였을때는 396 K

몇배 차이냐....   


● 값으로 지우기
Array.prototype.removeByValue = function() {
	if(!Array.prototype.indexOf) {
	    Array.prototype.indexOf = function(what, i) {
	        i = i || 0;
	        var L = this.length;
	        while (i < L) {
	            if(this[i] === what) return i;
	            ++i;
	        }
	        return -1;
	    };
	}
    var what, a = arguments, L = a.length, ax;
    while (L && this.length) {
        what = a[--L];
        while ((ax = this.indexOf(what)) !== -1) {
            this.splice(ax, 1);
        }
    }
    return this;
};


● 인덱스로 지우기
Array.prototype.removeByIdx = function(idx) {
    return (idx<0 || idx>this.length) ? this : this.slice(0, idx).concat(this.slice(idx+1, this.length));
};

'Web > 스크립트 일반' 카테고리의 다른 글

숫자 뒤 % 붙이기.  (0) 2017.11.30
숫자 외 몇몇 키 만 입력받기  (0) 2017.11.30
String to Date  (0) 2017.11.29
Object to XML  (0) 2013.11.07
자바스크립트 Array remove  (0) 2013.08.28

한반도 각 시/군/구 또는 광역시도의 데이터는 지역(Region)에 표시하고 특별한 지점(위/경도)도 표시하는 샘플..

티스토리 본문 창이 작은걸 감안하지 않고 페이지를 만들어서 범례가 짤리므로 새창으로 보는걸 추천...

시간이 없어서 복합 데이터 표출을 못한건 안자랑...
그러나 기존 유료 컴퍼넌트를 대체한건 자랑 


Result


Style

body{
	font-size: medium;
}
.jvm-legend {
	line-height: 2em;
	margin-top: 5px;
}
.jvm-legend span {
	vertical-align: middle;
}
.jvm-legend-item {
	width: 2em;
	height: 2em;
	display: inline-block;
	border-style : solid;
	border-color : black;
	border-width : 1px; 
}

.jvm-legend-item-15 {
	background: red;
}
.jvm-legend-item-10 {
	background: orange;
}
.jvm-legend-item-5 {
	background: yellow;
}
.jvm-legend-item-0 {
	background: white;
}

table .td-legend{
	padding-left: 10px
} 

Source

	function numberFormatComma(n) {
		var reg = /(^[+-]?\d+)(\d{3})/;   // 정규식
		n += '';                          // 숫자를 문자열로 변환
		while (reg.test(n)){
			n = n.replace(reg, '$1' + ',' + '$2');
		}
		return n;
	}

	var jMap = null;
	function convert(latitude, longitude) {
		// lat : 위도, long : 경도
		
		// QGIS > SVG 플러그인 속성에 적은 가로-세로
		var width = 823;
		var height = 823;

		// QGIS > SVG 플러그인 속성에서 SET 된 각 한계선
		var eastLong = 132.054062;		// 우측 한계선
		var westLong = 124.410858;		// 좌측 한계선
		var northLat = 39.686848;		// 상측 한계선
		var southLat = 32.043644;		// 하측 한계선
		
		// 경도 -> x
		var longDiff = eastLong - westLong;
		var lon = (longitude - westLong) * (width / longDiff);
		
		// 위도 -> y
		var latDiff = northLat - southLat;
		var lat = (northLat - latitude) * (height / latDiff);
		
		return [ lon, lat];
	}
	
	var sourceData = [
	                  {stnId : '105',	stnNm : '강릉',		lati : '37.75147',	lngt : '128.89098', heatWave : 10},
	                  {stnId : '295',	stnNm : '남해',		lati : '34.81663',	lngt : '127.92641', heatWave : 11},
	                  {stnId : '104',	stnNm : '북강릉',		lati : '37.80456',	lngt : '128.85535', heatWave : 11},
	                  {stnId : '255',	stnNm : '북창원',		lati : '35.2264',	lngt : '128.6725',  heatWave : 16},
	                  {stnId : '121',	stnNm : '영월',		lati : '37.18126',	lngt : '128.45743', heatWave : 18},
	                  {stnId : '211',	stnNm : '인제',		lati : '38.05987',	lngt : '128.16713', heatWave : 7},
	                  {stnId : '192',	stnNm : '진주',		lati : '35.16379',	lngt : '128.04002', heatWave : 14},
	                  {stnId : '155',	stnNm : '창원',		lati : '35.1702',	lngt : '128.57285', heatWave : 16},
	                  {stnId : '95',	stnNm : '철원',		lati : '38.14788',	lngt : '127.3042',   heatWave : 8},
	                  {stnId : '216',	stnNm : '태백',		lati : '37.17031',	lngt : '128.98928', heatWave : 1},
	                  {stnId : '162',	stnNm : '통영',		lati : '34.84546',	lngt : '128.4356',   heatWave : 3}
                  ];
	var markers = [];
	jQuery.each(sourceData, function(){
		var obj = {};
		var color = '';
		obj.coords = convert(this.lati, this.lngt);
		obj.stnNm = this.stnNm;
		obj.stnId = this.stnId;
		obj.heatWave = this.heatWave;
		obj.style = {};
		var val = Number(obj.heatWave);
		if(val >= 15){
			color = 'red';
		}
		else if(val >= 10){
			color = 'orange';
		}
		else if(val >= 5){
			color = 'yellow';
		}
		else {
			color = 'white';
		}
		
		obj.style.fill = color;
		obj.style.r = 5;
		markers.push(obj);
	});
	
	var countryData = []; 
	// 진주시
	countryData['38030'] = 339445;
	countryData['38050'] = 144017;
	countryData['38060'] = 116688;
	countryData['38070'] = 523177;
	countryData['38080'] = 110516;
	countryData['38090'] = 241711;
	countryData['38100'] = 270933;
	countryData['38310'] = 30728;
	countryData['38320'] = 70100;
	countryData['38330'] = 63766;
	countryData['38340'] = 58902;
	
	countryData['11010'] = 143089;
	countryData['11020'] = 143089;
	countryData['11030'] = 256614;
	countryData['11040'] = 307801;
	countryData['11050'] = 385874;
	countryData['11060'] = 377467;
	countryData['11070'] = 425101;
	countryData['11080'] = 492429;
	countryData['11090'] = 347817;
	countryData['11100'] = 365404;
	countryData['11110'] = 605521;
	countryData['11120'] = 506691;
	countryData['11130'] = 321183;
	countryData['11140'] = 395754;
	countryData['11150'] = 501855;
	countryData['11160'] = 574777;
	countryData['11170'] = 456694;
	countryData['11180'] = 262228;
	countryData['11190'] = 430516;
	countryData['11200'] = 414415;
	countryData['11210'] = 543477;
	countryData['11220'] = 441645;
	countryData['11230'] = 568685;
	countryData['11240'] = 686472;
	countryData['11250'] = 494186;

	$(document).ready(function() {
		width = $('#jvm_worldMap').width();

		jMap = $('#jvm_worldMap').vectorMap({
			map : 'korea_mill_en',
			markerStyle : {
				initial : {
					fill : '#F8E23B',
					stroke : '#383f47'
				}
			},
			series : {
				regions : [ {
					values : countryData,
					scale : [ '#C8EEFF', '#0071A4' ],	// two colors: for minimum and maximum values 
					normalizeFunction : 'polynomial'
				} ]
			},
			markers : markers,
			markerStyle : {
				hover: {
					stroke: 'black',
					r : 10
				},
			},
            onMarkerLabelShow: function(e, el, idx) {
           		var msg = el.html();
            	var source = markers[idx];
            	var mapObject = jMap.vectorMap('get', 'mapObject');
            	msg += ""+source.stnNm+"";
            	msg += "
지점ID : "+source.stnId+""; msg += "
폭염일수 : "+source.heatWave+""; // 맵 다시 그리기.. mapObject.onResize(); el.html(msg); }, //----------------------------------------------- // changed to onRegionLabelShow from onLabelShow //----------------------------------------------- onRegionLabelShow: function(e, el, code) { jQuery.each(countryData, function(name, value){ if(name == code && value != undefined){ el.html(el.html() + "
인구 : "+ numberFormatComma(Number(value))); return; } }); } }); var map = $('#jvm_worldMap').vectorMap('get', 'mapObject'); var range = [50000, 100000, 300000, 500000]; jQuery(range).each(function(idx, value){ color = map.series.regions[0].scale.getValue(value); var span = jQuery('').addClass('jvm-legend-item').css('background', color); var valSpan = jQuery('').append(' '+numberFormatComma(value)); jQuery('#regionDiv').append(span).append(valSpan).append('
'); }); });


HTML
	
지점 범례
> 15
> 10
> 5
> 0

지역 범례

  1. 츤데레 2013.11.25 12:18 신고

    안녕하세요. JVectorMap을 이용하고 있는데요..

    마커를 찍고있는데요...

    스위스라는 글이 적히면 스위스에 마커를 표시해야하는데

    lat과 lng를...알아내는 함수가 혹시 존재하나요..?

    • 안녕하세요.
      어떤 맵을 사용하시는지요..?
      기본적인 world-map 사용하시면 lati, lngt로 지점을 표시하실 수 있어요.
      그리고 마우스 동작이 아닌 이벤트로 마커를 표시하는건 구현되어 있지 않을겁니다.

      귀찮아서 저도 못한다고 그러고 넘어갔네요.. ;;

  2. 츤데레 2013.11.25 16:10 신고

    안녕하세요.

    빠른 답변 감사합니다.;

    jquery-jvectormap-1.2.2.min.js 요것을 사용중이구요..

    좀 더 자세히 설명드리면 맵이 로드될 때 해당 나라에 대한 글이 있으면 해당 나라에 마커를 찍어줘야하는데

    도저희 좌표를 알 방법이 없어서.. 이거 일일이 구현해줘야하나요? 따로 API가 존재하는지가 궁금했었습니다..

    이벤트라기 보다는 맵이 로딩될 때 마커를 그려줘야해요..

    현재 스위스에 글을 적으면 객체가 생성되며 이 객체는 국가 코드를 가지고 있고요... JVectorMap에도 regions안에 국가 코드가 있잖아요? 여기서 이 두 코드를 if문 처리하여 true가 반환될 때, 해당 국가에 마커를 그리고 싶은데..ㅠㅠ 좌표가없어서 그리질못하고 있습니당..

    좌표를 첨에 강제적으로 박아주는 방법뿐이 없나요? 그것이 싫어서 이렇게 고생하고 있습니다...

    • 방법이 없으면 그냥 그리면 됩니다...;;

      오늘 작업해볼게요...

      세계지도를 기준으로 국가의 중앙에 마커를 표시하는 샘플을 만들어 올릴테니 참고하시면 될거 같네요..

  3. 츤데레 2013.11.25 18:26 신고

    헉 감사합니다... 현재 point까지 구했는데 map.pointToLatLng 이놈이 자꾸 없는 함수라고 나오네요 크흑..감사합니다. ㅠ

  4. 츤데레 2013.11.26 09:40 신고

    저는 포인트는 구했어요

    https://github.com/bjornd/jvectormap/issues/146 에 있습니다. map의 이름이 달랐어요 ㅠㅠ 저는 mapObject로 설정했는데 ㅠㅠ뻘짓...

  5. 츤데레 2013.11.26 11:52 신고

    좌표가 올바른 좌표가 아니네요...그래도 컨버팅하는 방법은 저것이 맞습니다..

    • 위 계산식으로 하면 좌표가 안찍혀요 ~

      지금 계산한거가... 경도는 맞는데 위도가 안맞네요..
      일단 오늘 저녁에 웹에 올릴게요 -



Ubuntu 로케일 확인..

jyeory@jyeory:~$ locale

LANG=ko_KR.EUC-KR

LANGUAGE=ko_KR:ko

LC_CTYPE="ko_KR.EUC-KR"

LC_NUMERIC="ko_KR.EUC-KR"

LC_TIME="ko_KR.EUC-KR"

LC_COLLATE="ko_KR.EUC-KR"

LC_MONETARY="ko_KR.EUC-KR"

LC_MESSAGES="ko_KR.EUC-KR"

LC_PAPER="ko_KR.EUC-KR"

LC_NAME="ko_KR.EUC-KR"

LC_ADDRESS="ko_KR.EUC-KR"

LC_TELEPHONE="ko_KR.EUC-KR"

LC_MEASUREMENT="ko_KR.EUC-KR"

LC_IDENTIFICATION="ko_KR.EUC-KR"

LC_ALL=

 
서버 자체 인코딩을 변경해야지.. 

sudo vi /etc/default/locale

LANG="ko_KR.EUC-KR"

LANGUAGE="ko_KR:ko"


를 아래로... 

LANG="ko_KR.utf8"

LANGUAGE="ko_KR:ko"



그냥 사용중인 쉘에서만 잠시 변경할거라면...

export LANG=ko_KR.utf8  

 
 

'Server > Ubuntu' 카테고리의 다른 글

SVN 인증 캐시 지우기.  (0) 2014.04.30
useradd , adduser  (0) 2013.10.06
Character Set 확인 및 변경  (0) 2013.08.08
make install  (0) 2013.07.16
SVN 다중 저장소  (0) 2013.06.13
Ubuntu 12.0.4 Oracle 11g R2 설치.  (0) 2013.01.08

+ Recent posts