본문 바로가기

분류 전체보기730

Module was compiled with an incompatible version of Kotlin. The binary version of its metadata is 1.8.0, expected version is 1.6.0. 안드로이드 스튜디오에서 APK 컴파일 잘되던 프로제트가 갑자기 오류가 발생했습니다.gradle의 버전을 올리긴 했는데, 그것이 문제인지 잘 모르겠네요.해결 방법은 settings.gradle의  pluginManagerment 내에 아래의 플러그인을 추가해주면 해결됩니다.pluginManagement { repositories { gradlePluginPortal() google() mavenCentral() maven { url "https://www.jitpack.io" } } plugins { id "org.jetbrains.kotlin.android" version "1.9.22" apply false }} 2024. 9. 18.
안드로이드 프로젝트 Gradle 업그레이드 쉽게 하기 안드로이드 프로젝트의  Gradle을 쉽게 업그레이드 하는 방법입니다.메뉴를 몇번만 클릭하면  Gradle 업그레이드가 됩니답니다.^^ 1. Tools > AGP Upgrade Assistant...를 클릭합니다. 2. Gradle 버전을 선택합니다. 3. Run Selected steps 버튼을 클릭하면  Gradle이 업그레이드 됩니다. 2024. 7. 14.
Javascript 로더(Loader) 만들기 자바스크립터와 CSS로 간단하게 로더를 만드는 코드입니다.jquery 라이브러리를 함께 사용합니다. CSS.loadingPopup { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.1); z-index: 1000; justify-content: center; align-items: center;}.spinner { position: absolute; top: 50%; left: 50%; border: 8px solid #f3f3f3; /* Light grey */ border-top: 8px .. 2024. 7. 4.
[iOS] 스토리보드(Storyboard)에서 ImageView Tint Color 적용하기 스토리보드에서 ImagView를 추가하고 Tint에 색상을 변경하여도 작동하지 않습니다.Accets 이미지의 렌더러 모드를 템플릿으로 변경하고 ImageView의 Tint 색상을 변경하면 적용된다.1. Accet 이미지를 템플릿으로 변경한다. 2. ImageView의 Tint를 변경한다. 참고 : 아래는 코드로 ImageView의 Tint 색상을 변경하는 방법입니다.cell.ivRoute.image = UIImage(named: "route_busstop")?.withRenderingMode(.alwaysTemplate)cell.ivRoute.tintColor = .red 2024. 5. 9.
[iOS] Alamofire 한글(EUC-KR) 인코딩하기 Alamofire를 사용할 때 EUC-KR로 된 경우 한글이 깨지는데 Response을 인코딩 하는 방법입니다.Alamofire.request(strUrl).responseData() { response in switch response.result { case .success(let data): let dataString = NSString(data: data, encoding: CFStringConvertEncodingToNSStringEncoding(CFStringEncoding(CFStringEncodings.EUC_KR.rawValue))) let strHtml = dataString as? String ?? "" let doc = try Swif.. 2024. 5. 8.
[iOS] String 한글(EUC-KR) 인코딩 대부분의 우리나라 사이트는 인코딩 UTF-8로 사용하고 있지만, 관공서의 사이트는 EUC-KR을 사용하는 곳이 많습니다.관공서 사이트를 크롤링하려면 파라메터 등을 EUC-KR로 처리해야 하는데 아래의 함수로 처리하였습니다. static func euckrEncoding(_ query: String) -> String { //EUC-KR 인코딩 let rawEncoding = CFStringConvertEncodingToNSStringEncoding(CFStringEncoding(CFStringEncodings.EUC_KR.rawValue)) let encoding = String.Encoding(rawValue: rawEncoding) let eucKRStri.. 2024. 5. 8.
[iOS] Command PhaseScriptExecution failed with a nonzero exit code iOS 개발을 할 때 디버거로 컴파일하고 시뮬레이터에 앱이 잘 실행되는데 앱스토어에 앱을 올리기 위해서 Product > Archive 실행하니 아래와 같은 오류가 발생합니다.Command PhaseScriptExecution failed with a nonzero exit code해결방법은 아래의 위치에서 source="$(readlink "${source}")"를 source="$(readlink -f "${source}")"와 같이 변경 후 다시 Archive 를 실행하면 정상적으로 컴파일됩니다. 2024. 5. 7.
iOS Swift TextField 클리어 버튼 시 소프트 키보드 올라오는 현상 해결방법 TextField의 클리어 버튼을 탭하면 TextField의 내용이 지워지고, 소프트 키보드가 올라오는데 이 키보드가 올라오지 않게 하는 간단한 방법입니다.약간의 꽁수를 썼는데, 크리어 버튼이 눌러질 때 TextFiel의 isEnabled를 false로 지정해서 비활성화 시키고 DispatchQueue를 이용하여 0.1초 후 다시 활성화를 시켜서 문제를 해결했습니다.  func textFieldShouldClear(_ textField: UITextField) -> Bool { searchRecent() tfSearch.isEnabled = false DispatchQueue.main.asyncAfter(deadline: .now().. 2024. 5. 6.
[iOS] Sandbox: rsync.samba... 오류 해결 방법 iOS 프로젝트에 Tabman 라이브러리를 CocoaPods로 적용 후 아래와 같은 오류가 발생했습니다. 구글링해서 찾아보니 프로젝트 Build Settings에서 User Script Snadboxing의 값을 No로 설정하고 다시 빌드하면 오류가 발생하지 않습니다. 2024. 4. 25.
[iOS] xcode 프로젝트에 CocoaPods 사용하기 xcode 프로젝트를 생성하고 CocoaPods로 라이브러리를 사용하기 위한 작업순서입니다.개인적으로 안드로이드와 iOS를 함께 개발 하다보니 새로운 iOS 프로젝트를 생성하고 CocoaPods 사용하는 방법을 잊어서 정리합니다. 1. 터미널로 xcode 프로젝트 폴더로 이동합니다.2. CocoaPods을 적용합니다.pod init아래와 같이  Podfile 파일이 생성됩니다. 3. Podfile에 라이브러리(pod 'Tabman', '~> 3.2' )를 추가했습니다.# Uncomment the next line to define a global platform for your project# platform :ios, '9.0'target 'TabTest' do # Comment the next l.. 2024. 4. 25.
자바스크립트 크롬에서 엣지로 링크 열기 특별한 경우 크롬에서 엣지 브라우저로 링크를 열어야 하는 경우가 있습니다. 예를 들면 회사에 엣지 기반으로 개발된 시스템은 크롬에서 정상 작동을 하지 않을 경우에 크롬 기반으로 개발하는 시스템에서 엣지 기반의 타 시스템을 엣지로 열어야 할 때입니다. 참고 : 반대로 엣지에서 크롬으로 여는 것은 안되네요. ㅠㅠ 자바스크립트 코드는 간단합니다. URL에 앞에 "microsoft-edge:"를 붙여주기만 하면 됩니다. 자바스크립트 예 window.location = "microsoft-edge:" + "https://www.naver.com"; HTML 예 엣지로 네이버 열기 2023. 11. 8.
자바스크립트 ==와 ===의 차이점 최근 개발하면서 프로그램에 버그가 발생하였습니다. 버그는 자바스크립트로 아래와 같이 처리 했는데, if문이 참이 되어 발생한 것이었습니다. 그래서 === 비교 연산자를 사용하여 버그를 수정하였습니다. var a = 0; var b = ""; if(a == b){ // true ... } ==와 === 비교 연산자의 차이점을 알아야 할 것 같습니다. == 연산자는 값만 비교하고, === 연산자는 값과 타입을 함께 비교하게 됩니다. 즉 1 == "1" 는 true이고, 1 === "1"은 false가 된다는 것입니다. 간단하 예제로 확인해보겠습니다. 숫자와 문자 비교 console.log(1 == "1");// true console.log(1 ==="1");// false 숫자와 참거짓 비교 console.. 2023. 10. 25.
자바스크립트 "YYYY-MM-DD" 형식의 문자 날짜 체크 자바스크립트로 날짜 정확한 날짜를 체크하는 것이 약간 애매합니다. Date.parse를 사용하면 좋은데, 단점이 2월 30일(2023-02-30)을 아규먼트로 넣어도 오류(NaN)가 발생하지 않는 현상이 발생합니다. 그리고 new Date("2023-02-30")로 넣어도 오류가 발생하지 않아 try catch를 할 수 없습니다. 날짜 문자(YYYY-MM-DD)를 체크 로직 순서는 아래과 같이 작성합니다. (1) YYYY-MM-DD 형식 체크 (2) Date.parse를 이용하여 정확한 날짜 체크 (3) new Date(...).toISOString() 함수로 날짜 문자와 Date형으로 형변환한 값이 동일한지 체크 1. YYYY-MM-DD 형식 체크 날짜 문자의 길이는 10이고, "-"로 문자를 분리한 .. 2023. 8. 29.
Privacy Policy Who I am This blog address is: https://docko.tistory.com Comments When visitors leave comments on this blog, we collect the data shown in the comments form and also the visitor’s IP address and browser user agent string to help spam detection. Embedded content from other websites Articles on this site may include embedded content (e.g. videos, images, articles, etc.). Embedded content from other.. 2023. 8. 7.
[SlickGrid] 셀(Cell)에 툴팁(Tooltip) 표시하기 SlickGrid의 Header의 툴팁은 컬럼 정의에서 속성으로 처리를 할 수 있습니다. 셀의 경우는 좀 다르게 처리를 해야 셀에 툴팁을 표시 할 수 있습니다. 즉, 셀에 Format을 적용하여 처리를 해야 하네요. 1. SlickGrid Version 아래의 예는 SlickGrid v2.4에서 테스트 했으며, 하위 버전에서는 작동하지 않을 수도 있습니다. 2. 툴팁을 위한 Format 함수 셀에 툴팀을 표시하기 위해서는 Format의 리턴 값을 JSONObject로 속성 text와 toolTip을 갖고 있어야 합니다. text는 그리드 셀에 표시되고, toolTip은 셀에 마우스 오버가 되면 툴팁으로 표시됩니다. function tooltipCellFormat(row, cell, value, colum.. 2023. 7. 13.
MSSQL - 프로시저에서 SELECT 절의 값을 변수에 할당하는 방법 MSSQL 프로시저에서 변수를 선언하고 SELECT절의 값을 변수에 할당하는 방법입니다. 변수 선언 DECLARE @변수명 데이터타입; DECLARE @INT_VAL INT; DECLARE @STR_VAL VARCHAR(200); 변수에 값 할당 변수에 값을 할당 할때는 앞에 SET을 기술하고 할당하면 됩니다. SET @INT_VAL = 10; SET @STR_VAL = 'ABCDED'; SELECT 절의 여러 값을 변수에 할당 하는 방법 SELECT 절의 여러 컬럼의 값을 할당 할 수도 있습니다. ROW가 여러개인 경우 마지막 값이 할당되는점 주의하세요. DECLARE @INT_VAL INT; DECLARE @STR_VAL VARCHAR(200); WITH TEST AS ( SELECT 10 VAL1,.. 2023. 7. 12.
MSSQL 문자 함수 모음 MSSQL에서 사용 할 수 있는 문자 관련 함수입니다. ASCII : 왼쪽 첫번째 문자의 ASCII코드 값을 반환 -- ASCII(character_expression) SELECT ASCII('ABC') CHAR : ASCII 코드를 문자로 변환 -- CHAR (integer_expression) SELECTchar(65) CHARINDEX : expression2에서 expression1의 시작 INDEX 반환, 없으면 0 반환 -- CHARINDEX( expression1,expression2 [ , start_location] ) SELECT CHARINDEX('다', '가나다라마', 2) LEFT, RIGHT : 문자열의 왼쪽 또는 오른쪽부터 지정된 수만큼의 문자를 반환 -- LEFT,RIGHT.. 2023. 6. 28.
MSSQL 여러 Row를 하나로 합치기 여러 ROW의 컬럼의 값을 하나로 합치는 방법입니다. XML 만드는 쿼리를 이용하는데, 아래와 같이 쿼리를 실행하면 NAME 태그로 XML이 표시됩니다. WITH A AS ( SELECT '이순신' NAME UNION ALL SELECT '홍길동' NAME UNION ALL SELECT '김유신' NAME ) SELECT NAME FROM A ORDER BY NAME FOR XML PATH('') XML 태그를 없애기 위해서는 컬럼명을 지정하시 않게 해야 하는데, 구분자(,)를 넣고 ALIAS(별칭)를 지정하지 않습니다. WITH A AS ( SELECT '이순신' NAME UNION ALL SELECT '홍길동' NAME UNION ALL SELECT '김유신' NAME ) SELECT ',' + NA.. 2023. 6. 28.
MSSQL WITH NOLOCK 설정하기 MSSQL에서 트랜잭션이 진행중인 테이블을 SELECT 하면 트랜잭션이 끝날때까지 SELECT는 팬딩됩니다. 트랜잭션이 끝날때까지 기다리지 않고 SELECT 하기 위해서는 FROM절의 테이블마다 WITH (NOLOCk)를 넣어 주어야 합니다. SELECT * FROM [테이블명] WITH(NOLOCK) 매번 테이블에 WITH(NOLOCK)을 넣기에는 너무 귀찮죠..^^ SELECT 쿼리 수행 전에 아래의 와 같이 NOLOCK을 설정하면 FORM 절에 WITH(NOLOCK) 을 넣지 않아도 됩니다. SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED; 2023. 6. 22.
MSSQL 여러 컬럼의 MIN, MAX, SUM, AVG 구하기 하나의 Row에 여러 컬럼 중 최소값, 최대값, 합계 등을 구하는 방법입니다. 많이 사용하지 않는 쿼리지만 알고 있으면 힘이 되겠죠. 아래의 간단한 예제를 보고 쉽게 따라 할 수 있을 겁니다. WITH T AS ( SELECT 12 A, 13 B, 56 C, 123 D, 3 E ) SELECT (SELECT MIN(COL) FROM (VALUES (A), (B), (C), (D), (E)) AS V(COL)) MIN_VAL, -- 최소값 (SELECT MAX(COL) FROM (VALUES (A), (B), (C), (D), (E)) AS V(COL)) MAX_VAL, -- 최대값 (SELECT SUM(COL) FROM (VALUES (A), (B), (C), (D), (E)) AS V(COL)) SUM.. 2023. 6. 13.
맥북 FHD 모니터 폰트 흐림 해결 맥북을 사용한지 6개월정도 되었고 아직도 적응 중에 있습니다. 엘지 FHD 모니터를 구입했는데, 이런 폰트가 흐리네요. ㅠㅠ 구글링을 해서 찾아보니 맥북에 외부모니터는 4K모니터를 구입해야 한다는 거였습니다. 그래도 포기 할 수 없어서 더 구글링을 해서 폰트를 부드럽게 하는 옵션을 조정하여 폰트 흐림 현상을 해결 했습니다. 아래의 명령을 터미널에서 실행하고, 맥북을 재시동하는 작업을 수행하면 최적의 환경을 찾아보세요. 옵션 활성화 (기본 무난한 설정 값) : defaults -currentHost write -g AppleFontSmoothing -int 0 Light Font 옵션 (약간 얇은 폰트) : defaults -currentHost write -g AppleFontSmoothing -int .. 2023. 5. 12.