Android – Esconder o teclado do android programaticamente ‘forçado’ (Hide keyboard programmatically)

keyboard_android

easy workaround:

           InputMethodManager imm = (InputMethodManager) getActivity().getSystemService(Context.INPUT_METHOD_SERVICE);
           imm.hideSoftInputFromWindow(getActivity().getCurrentFocus().getWindowToken(), 0);

Java – Ler um arquivo e codifica-lo para Base64 – Converter File para Base64 (Encode file to Base64)

java

 private String encodeFileToBase64Binary(File file)
            throws IOException {

        byte[] bytes = loadFile(file);
        byte[] encoded = Base64.getEncoder().encode(bytes);
        String encodedString = new String(encoded);

        return encodedString;
    }

    private byte[] loadFile(File file) throws IOException {
        byte[] bytes;
        try (InputStream is = new FileInputStream(file)) {
            long length = file.length();
            if (length > Integer.MAX_VALUE) {
                throw new IOException("File to large " + file.getName());
            }
            bytes = new byte[(int) length];
            int offset = 0;
            int numRead = 0;
            while (offset < bytes.length
                    && (numRead = is.read(bytes, offset, bytes.length - offset)) >= 0) {
                offset += numRead;
            }
            if (offset < bytes.length) {
                throw new IOException("Could not completely read file " + file.getName());
            }
        }
        return bytes;
    }

Rotate YUV image – rotate byte[] yuv image

Rotate YUV image – rotate byte[] yuv image

public class YuvHelper {

	public static byte[] rotateYUV420Degree90(byte[] data, int imageWidth,
			int imageHeight) {
		byte[] yuv = new byte[imageWidth * imageHeight * 3 / 2];
		// Rotate the Y luma
		int i = 0;
		for (int x = 0; x < imageWidth; x++) {
			for (int y = imageHeight - 1; y >= 0; y--) {
				yuv[i] = data[y * imageWidth + x];
				i++;
			}
		}
		// Rotate the U and V color components
		i = imageWidth * imageHeight * 3 / 2 - 1;
		for (int x = imageWidth - 1; x > 0; x = x - 2) {
			for (int y = 0; y < imageHeight / 2; y++) {
				yuv[i] = data[(imageWidth * imageHeight) + (y * imageWidth) + x];
				i--;
				yuv[i] = data[(imageWidth * imageHeight) + (y * imageWidth)
						+ (x - 1)];
				i--;
			}
		}
		return yuv;
	}

	public byte[] rotateYUV420Degree180(byte[] data, int imageWidth,
			int imageHeight) {
		byte[] yuv = new byte[imageWidth * imageHeight * 3 / 2];
		int i = 0;
		int count = 0;
		for (i = imageWidth * imageHeight - 1; i >= 0; i--) {
			yuv[count] = data[i];
			count++;
		}
		i = imageWidth * imageHeight * 3 / 2 - 1;
		for (i = imageWidth * imageHeight * 3 / 2 - 1; i >= imageWidth
				* imageHeight; i -= 2) {
			yuv[count++] = data[i - 1];
			yuv[count++] = data[i];
		}
		return yuv;
	}

	public byte[] rotateYUV420Degree270(byte[] data, int imageWidth,
			int imageHeight) {
		byte[] yuv = new byte[imageWidth * imageHeight * 3 / 2];
		int nWidth = 0, nHeight = 0;
		int wh = 0;
		int uvHeight = 0;
		if (imageWidth != nWidth || imageHeight != nHeight) {
			nWidth = imageWidth;
			nHeight = imageHeight;
			wh = imageWidth * imageHeight;
			uvHeight = imageHeight >> 1;// uvHeight = height / 2
		}
		
		int k = 0;
		for (int i = 0; i < imageWidth; i++) {
			int nPos = 0;
			for (int j = 0; j < imageHeight; j++) {
				yuv[k] = data[nPos + i];
				k++;
				nPos += imageWidth;
			}
		}
		for (int i = 0; i < imageWidth; i += 2) {
			int nPos = wh;
			for (int j = 0; j < uvHeight; j++) {
				yuv[k] = data[nPos + i];
				yuv[k + 1] = data[nPos + i + 1];
				k += 2;
				nPos += imageWidth;
			}
		}
		return rotateYUV420Degree180(yuv, imageWidth, imageHeight);
	}
}

Fonte: https://github.com/wzystal/MediaRecorder/blob/master/src/com/baidu/mediarecorder/util/YuvHelper.java

Android – Como converter um byte[] em um objeto Mat utilizando o OpenCV no Android (How to get the Mat object from the Byte[] in openCV android?)

open_cv
Simples assim:

Mat mat = Imgcodecs.imdecode(
    new MatOfByte(bytes), Imgcodecs.CV_LOAD_IMAGE_UNCHANGED
);

Como converter um Bitmap em um objeto Mat:

import org.opencv.android.Utils;

Mat mat = new Mat();    
Bitmap bmp32 = bmp.copy(Bitmap.Config.ARGB_8888, true);
Utils.bitmapToMat(bmp32, mat);

Android – Detecção facial utilizando o OpenCV (OpenCV in Android Studio with face detect)

open_cv

Detecção facial utilizando OpenCV no Android – OpenCV in Android Studio with face detect

This application is a sample Android Studio project (tested on gradle 3.0.1) with ‘Android SDK OpenCV 3.3.1′

Project: https://github.com/helpdeveloper/AndroidFaceDetectOpenCV

Usage:

Here is how to use this project to run native OpenCV code.

  • Make sure you have Android SDK up to date, with NDK installed
  • Download latest OpenCV SDK for Android from OpenCV.org and decompress the zip file.
  • Clone this project
  • Create a symlink named jniLibs in app/src/main that points to YOUR_OPENCV_SDK/sdk/native/libs
  • In app/CMakeLists.txt change line 9 to points to YOUR_OPENCV_SDK/sdk/native/jni/include
  • Sync gradle
  • Run the application

-> README FILE -<

 

Android / Gradle 3.0.X – Error:All flavors must now belong to a named flavor dimension. Learn more at ….

gradle

Erro: todos os sabores devem agora pertencer a uma dimensão de sabor nomeada.

Simples solução, em seu build.gradle:

android{
    ...
    flavorDimensions "default"
    productFlavors{
        flavor1{...}
        flavor2{...}
    }
}

Claro que ficou bem mais abrangente os flavors, para mais informações: https://developer.android.com/studio/build/build-variants.html#flavor-dimensions

Maven – Adicionando / Instalando um Jar no seu repositório local Maven (Generating a generic POM – install external Jar file to local repo)

mavenHá momentos em que você não tem um POM para um artefato de terceiros. Por exemplo, ao utilizar um JAR proprietário ou comercial. O install-plugin pode criar um POM genérico neste caso, que contém o conjunto mínimo de elementos POM exigidos pelo Maven, como groupId, artifactId, version, packaging. Você diz a Maven que gere um POM configurando o parâmetro generatePom como true.

Conseguimos fazer isso com o seguinte comando:

mvn org.apache.maven.plugins:maven-install-plugin:2.5.2:install-file \
    -Dfile=home/helpdev/jars/MyLib.jar \
    -DgroupId=br.com.helpdev \
    -DartifactId=MyLib \
    -Dversion=2.0.0 \
    -Dpackaging=jar \
    -DgeneratePom=true \
    -DupdateReleaseInfo=true

#configuração para deploy em outro dir sem ser seu local repo.
#-DlocalRepositoryPath=local-maven-repo

Fonte: http://maven.apache.org/plugins/maven-install-plugin/examples/generic-pom-generation.html

Maven – Configurando proxy (Maven Configuring a proxy)

maven

Para configurar o proxy no Maven basta criar ou editar o arquivo de configuração settings.xml no diretorio: ${user.home}/.m2/settings.xml
Caso você queira configurar para apenas um projeto, é só inserir esse arquivo junto ao diretorio aonde esta seu pom.xml.

 

    <settings>
      .
      .
      <proxies>
       <proxy>
          <id>example-proxy</id>
          <active>true</active>
          <protocol>http</protocol>
          <host>proxy.example.com</host>
          <port>8080</port>
          <username>proxyuser</username>
          <password>somepassword</password>
          <nonProxyHosts>www.google.com|*.example.com</nonProxyHosts>
        </proxy>
      </proxies>
      .
      .
    </settings>

Fonte: https://maven.apache.org/guides/mini/guide-proxies.html

Java/Kotlin -Utilizando um unico array para os argumentos do String.format() (String.format() takes an array as a single argument)

java_kotlin

Como passar os argumentos de um String format em uma unica lista de parametros.

Em Java:

        
        String a = "V1: %s - V2: %s - V3: %s";
        List strings = new ArrayList();
        strings.add("var1");
        strings.add("var2");
        strings.add("var3");

        System.out.println(String.format(a, (Object[]) strings.toArray()));

Em Android utilizando Kotlin:

       
        val a = "V1: %s - V2: %s - V3: %s"
        val strings = ArrayList()
        strings.add("var1")
        strings.add("var2")
        strings.add("var3")

        println(String.format(a, *strings.toTypedArray() as Array<*>))

Android – Como alterar os atributos do TextView da mensagem de um Snackbar

Android

            snack = Snackbar.make(my_id_layout, myMessage, Snackbar.LENGTH_INDEFINITE);
            val view = snack!!.getView()
            val tv = view.findViewById<TextView>(android.support.design.R.id.snackbar_text)
            tv.setTextColor(Color.WHITE)
            tv.setTextSize(TypedValue.COMPLEX_UNIT_SP, 20f);
            snack!!.show()

Para uma simples alteração de cor podemos utilizar:

snack.setActionTextColor(Color.RED)

Ou:

 
Snackbar.make(view, 
       Html.fromHtml("Tap to open").show()

Também podemos alterar o background:

 snackbar.getView().setBackgroundColor(Color.BLACK);