정확하게는 재생이 안되는 것이 아니라 재생은 되는데, 화면이 안보일때 해결 방법

webview의 layter type을 softwore로 설정했다면 이를 삭제한다

webView.setLayerType(View.LAYER_TYPE_SOFTWARE, null);

와 같이 설정한 곳이 있으면 삭제 또는 LAYER_TYPE_HARDWARE  로 변경


LAYER_TYPE_SOFTWARE 는 Android version에 따라서 webview 성능 향상을 위해 사용하라는 의견들이 많다







Posted by incree

2017/02/10 05:49 2017/02/10 05:49
, , , ,
Response
0 Trackbacks , 0 Comments
RSS :
http://www.incree.com/tc/incree/rss/response/377

Trackback URL : 이 글에는 트랙백을 보낼 수 없습니다

[Android] Firebase 로 GCM 구현하기

구글 GCM이 Firebase로 바뀌면서 나중에 참고하기 위해서 정리한다

구글 계정이 있고, Android 프로젝트용

https://firebase.google.com/console/

사용자 삽입 이미지

구글계정이 있고 구글 계정과 연결해서 사용할때 firebase console에서 하단의 '여기를 클릭'을 클릭

사용자 삽입 이미지

Sign in with Google 클릭

사용자 삽입 이미지

허용 클릭

사용자 삽입 이미지

구글 계정으로 연동이 됐으면 다시 firebase console에서 '새 프로젝트 만들기'를 클릭한다

사용자 삽입 이미지

프로젝트 이름, 국가/지역을 선택하고 프로젝트 만들기를 클릭한다

사용자 삽입 이미지

프로젝트가 만들어 지면 프로젝트 화면으로 이동하는데, Notifications를 클릭하면 위 화면이 나온다. 운선 안드로이드를 클릭한다.

사용자 삽입 이미지

패키지 이름을 넣고 앱 추가를 클릭한다. - 중간에 설명처럼 Android Studio 2.2. 이상에서도 가능하다.

사용자 삽입 이미지

이전 단계에서 '앱 추가'를 클릭하면 자동으로 google-services.json이 다운로드 된다. 이 파일을 프로젝트에 추가한다.

사용자 삽입 이미지

gradle 파일을 수정하고 동기화 한 후 완료를 클릭한다
주의 : 2번 앱수순 gradle 파일 수정시 화살표의 'Add to the bottom of the file'를 반드시 지켜야 한다.

사용자 삽입 이미지

완료시 나오는 화면 앱 개발까지 완료되면 '첫 번째 메시지 보내기'를 클릭해서 테스트 하면 된다.

사용자 삽입 이미지

메시지를 발송해 본다



Posted by incree

2016/11/19 02:14 2016/11/19 02:14
, ,
Response
0 Trackbacks , 0 Comments
RSS :
http://www.incree.com/tc/incree/rss/response/371

Trackback URL : 이 글에는 트랙백을 보낼 수 없습니다

구글 클라우드 프린트를 이용해서 웹에 있는 파일(pdf) 인쇄하기

 전체 소스 : GoogleCloudPrintExample.zip




Android Integration
https://developers.google.com/cloud-print/docs/android

Posted by incree

2016/09/17 22:34 2016/09/17 22:34
,
Response
0 Trackbacks , 0 Comments
RSS :
http://www.incree.com/tc/incree/rss/response/369

Trackback URL : 이 글에는 트랙백을 보낼 수 없습니다

Custom ListView로 AlertDialog 띄우기


사용자 삽입 이미지

사용자 삽입 이미지

사용자 삽입 이미지


AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.incree.customalertdialog">

<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@android:style/Theme.NoTitleBar">
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN"/>

<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
</application>

</manifest>


MainActivity.java
package com.incree.customalertdialog;

import android.app.Activity;
import android.app.AlertDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.graphics.Color;
import android.graphics.drawable.ColorDrawable;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.text.TextUtils;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.CheckBox;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends Activity {

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

public void btnOpenPopupClickHandler(View view) {
final List<Product> items = new ArrayList<Product>();
items.add(new Product(1, "와퍼세트", "와퍼 단품+프렌치프라이R+콜라R", 8000, R.drawable.product_1));
items.add(new Product(2, "너겟킹10조각", "담백한 닭가슴살로 만든 바삭한 너켓킹", 5100, R.drawable.product_2));
items.add(new Product(3, "머쉬룸스테이크버거세트", "머쉬룸스테이크버거 단품+프렌치프라이R+콜라R", 9600, R.drawable.product_3));
items.add(new Product(4, "트리오팩", "통새우와퍼+와퍼+와퍼주니어+프렌치프라이(R)+치즈프라이+너겟킹4조각+어니언링+콜라(R)3", 24500, R.drawable.product_4));
items.add(new Product(5, "롱킹", "쇠고기 (호주산과 뉴질랜드산 섞음)", 6100, R.drawable.product_5));
final ProductListAdapter adapter = new ProductListAdapter(MainActivity.this, items);
AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this)
.setAdapter(adapter, null)
.setTitle("상품선택")
.setPositiveButton("선택구매", new DialogInterface.OnClickListener() { // 버튼은 테마에 따라서 모양이 다르게 모임
public void onClick(DialogInterface dialog, int whichButton) {
for(Product product : items) {
if (product.isSelected()) {
Log.d("MainActivity", product.getProductTitle() + " 선택");
}
}
}
})
.setNegativeButton("취소", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int whichButton) {
Log.d("MainActivity", "취소 터치");
}
});

AlertDialog alertDialog = builder.create();
final ListView listView = alertDialog.getListView();
listView.setAdapter(adapter);
//listView.setChoiceMode(ListView.CHOICE_MODE_MULTIPLE); // 여러 상품 선택을 위해 - 이 형태에서는 필요 없다
listView.setDivider(new ColorDrawable(Color.LTGRAY));
listView.setDividerHeight(1);
listView.setFocusable(false); // false를 해줘야 row touch event 가능
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
CheckBox cbGoLargeChecked = (CheckBox)view.findViewById(R.id.productChecked);
Product tmpVo = items.get(position);
tmpVo.setSelected(!tmpVo.isSelected());
cbGoLargeChecked.setChecked(tmpVo.isSelected());
}
});

alertDialog.show();
}
}


class ProductListAdapter extends BaseAdapter
{
private Activity activity;
private List<Product> dataList;

public ProductListAdapter(Activity activity, List<Product> dataList) {
this.activity = activity;
this.dataList = dataList;
}

@Override
public int getCount()
{
return dataList.size();
}

@Override
public Object getItem(int position)
{
return dataList.get(position);
}

@Override
public long getItemId(int position)
{
return position;
}

@Override
public View getView(int position, View convertView, ViewGroup parent)
{
View view = convertView;
if(view == null) {
LayoutInflater inflater = (LayoutInflater) activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
view = inflater.inflate(R.layout.product_dialog_list_row, null);
}

final Product data = dataList.get(position);

ImageView ivProductImage = (ImageView)view.findViewById(R.id.productImage);
final CheckBox cbProductChecked = (CheckBox)view.findViewById(R.id.productChecked);
TextView tvProductTitle = (TextView)view.findViewById(R.id.productTitle);
TextView tvProductDesc = (TextView)view.findViewById(R.id.productDesc);

cbProductChecked.setFocusable(false); // false를 해줘야 row touch event 가능

cbProductChecked.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
data.setSelected(cbProductChecked.isChecked());
}
});

ivProductImage.setImageDrawable(activity.getResources().getDrawable(data.getProductImageResource()));
tvProductTitle.setText(data.getProductTitle());
tvProductDesc.setText(data.getProductDesc());
cbProductChecked.setText(data.getProductPrice() + "원");
cbProductChecked.setChecked(data.isSelected());

return view;
}
}


activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
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="com.incree.customalertdialog.MainActivity">

<Button
android:id="@+id/btnOpenPopup"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:onClick="btnOpenPopupClickHandler"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:text="상품 팝업 열기"/>
</RelativeLayout>





product_dialog_list_row.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content">

<ImageView
android:id="@+id/productImage"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="3dp"
android:layout_centerVertical="true"/>

<TextView
android:id="@+id/productTitle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="3dp"
android:layout_marginTop="5dp"
android:layout_toRightOf="@id/productImage"
android:layout_alignParentTop="true"
android:hint="상품명"
android:textColor="#252525"
android:textSize="16sp"
android:textStyle="bold"/>

<CheckBox
android:id="@+id/productChecked"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginRight="3dp"
android:layout_alignParentRight="true"
android:layout_centerVertical="true"
android:layoutDirection="rtl"
android:textColor="#252525"
/>

<TextView
android:id="@+id/productDesc"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="3dp"
android:layout_marginTop="5dp"
android:layout_marginBottom="5dp"
android:layout_toRightOf="@id/productImage"
android:layout_toLeftOf="@id/productChecked"
android:layout_below="@id/productTitle"
android:hint="상품 설명"
android:textColor="#252525"
android:textSize="12sp"/>
</RelativeLayout>

 전체 소스 : CustomAlertDialog.zip


Posted by incree

2016/09/10 09:08 2016/09/10 09:08
, ,
Response
0 Trackbacks , 0 Comments
RSS :
http://www.incree.com/tc/incree/rss/response/368

Trackback URL : 이 글에는 트랙백을 보낼 수 없습니다

안드로이드 웹뷰 회전시 상태 유지

android:configChanges="orientation|keyboardHidden|screenSize"

screenSize 는 Android 3.2(API level 13) or higher device


Posted by incree

2016/06/01 22:16 2016/06/01 22:16
,
Response
0 Trackbacks , 0 Comments
RSS :
http://www.incree.com/tc/incree/rss/response/367

Trackback URL : 이 글에는 트랙백을 보낼 수 없습니다


Android Facebook 연동 작업시에 발생하는 에러 처리

1. Failed to find provider info for com.facebook.wakizashi.provider.PlatformProvider
1) Menifest에 INTERNET 퍼미션 추가
<uses-permission android:name="android.permission.INTERNET"></uses-permission>
2)

Posted by incree

2014/10/21 03:33 2014/10/21 03:33
,
Response
0 Trackbacks , 0 Comments
RSS :
http://www.incree.com/tc/incree/rss/response/360

Trackback URL : 이 글에는 트랙백을 보낼 수 없습니다

[Android] short array to byte array

public byte[] shortArray2byteArray(short[] shortArray) {
    int shortArraySize = shortArray.length;
    byte[] byteArray = new byte[shortArraySize * 2];
    for (int i = 0; i < shortArraySize ; i++) {
        byteArray [i * 2] = (byte) (shortArray[i] & 0x00FF);
        byteArray [(i * 2) + 1] = (byte) (shortArray[i] >> 8);
    }
    return byteArray ;
}

Posted by incree

2014/04/28 05:07 2014/04/28 05:07
, , ,
Response
0 Trackbacks , 0 Comments
RSS :
http://www.incree.com/tc/incree/rss/response/326

Trackback URL : 이 글에는 트랙백을 보낼 수 없습니다

[Android] TextToSpeech 버그(??)

TextToSpeech를 이용해서 앱을 개발하고 있는데,

영어 문장을 읽는데, 꼭 한국 사람이 영어 말하는 것처럼 발음이 재생됐다.

onInit 에서

if (tts.isLanguageAvailable(Locale.US) == TextToSpeech.LANG_AVAILABLE)
                tts.setLanguage(Locale.US);
로 언어를 세팅하는 코드를 넣었는데, 이 부분이 정상적으로(?) 작동하지 않았다.

조건문의 isLanguageAvailable 가 0을 리턴해야 정상적으로 실행이 되는데,

1이 리턴되었다.

인터넷 열심히 뒤져서 가져다 쓴 코든데,코드가 잘못 되었다.

아래 doc 문서 보면 위와 같이 사용해도 정상 작동해야 되는데,

http://developer.android.com/reference/ ··· ale.html
public static final Locale US Locale constant for en_US.

버그인지 아니면 폰의 특성을 타는지 정상작동하지 않았다.

Locale enUs = new Locale("en_US");
            if (tts.isLanguageAvailable(enUs) == TextToSpeech.LANG_AVAILABLE)
                tts.setLanguage(enUs);

이렇게 수정해야 정상작동 되었다.

문서상으로는 둘다 같은 코드인데......

왜 아래만 작동할까? 버그일까?



Posted by incree

2014/04/22 01:18 2014/04/22 01:18
, , , , , , ,
Response
0 Trackbacks , 0 Comments
RSS :
http://www.incree.com/tc/incree/rss/response/325

Trackback URL : 이 글에는 트랙백을 보낼 수 없습니다

Android에서 전역으로 사용하기 위해 정의한 정적변수가

어느 순간 초기화 돼 버리는 희안한 증상이 발생하는데,

이게 버그인지 메모리 부족을 해결하기 위한 원래 안도르이드의 정책인지 알수가 없다

java에서는 당연히 버그일텐데, 기기에 따라 발생안하는 경우도 있긴 하지만

안드로이드는 버그로 보기는 힘들거 같다.

버그든 아니든 앱의 비정상 작동을 막기 위해서는 먼가 방법을 찾아야 된다.

변경가능해야 하고 전역에서 영구적으로 사용하고 싶은 변수는

SharedPreferences에 저장해서 사용하면 위와 같은 문제는 발생하지 않는다.

Posted by incree

2013/09/03 18:00 2013/09/03 18:00
, ,
Response
0 Trackbacks , 0 Comments
RSS :
http://www.incree.com/tc/incree/rss/response/264

Trackback URL : 이 글에는 트랙백을 보낼 수 없습니다

[Android] 배경 터치시 키보드 감추기

Hide keyboard where touch background layout

onCreate에 다음 코드를 추가한다

mainLayout = (LinearLayout) findViewById(R.id.loginMainLayout);
mainLayout.setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
                imm.hideSoftInputFromWindow(loginId.getWindowToken(), 0);
            }
        });

주의 ** :
LinearLayout 에
android:focusable="true"
android:focusableInTouchMode="true"
이 속성이 있는 경우 onClickListener이 두번터치 해야 이벤트 파이어가 된다.
onClickListener를 사용하려면 위 두가지 속성 사용하면 안됨
2.1 에뮬레이터, 갤탭에서 테스트

Posted by incree

2012/02/21 21:08 2012/02/21 21:08
, , ,
Response
0 Trackbacks , 0 Comments
RSS :
http://www.incree.com/tc/incree/rss/response/100

Trackback URL : 이 글에는 트랙백을 보낼 수 없습니다


Notices

Archives

Authors

  1. incree

Recent Trackbacks

Calendar

«   2017/02   »
      1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28        

Site Stats

Total hits:
389701
Today:
36
Yesterday:
144