Como podemos ver tenemos 2 Activities. La primera de ellas (VisibleActivity) es la que estará en la parte de atrás de la Activity Transparente. La otra Activity (TransparentActivity) será la que estará situada sobrepuesta a la VisibleActivity.
La parte importante es añadir en el Manifest la línea de código que podemos ver destacada en rojo. En ella se puede ver com indicamos a la Activity que tendrá el tema transparente.
AndroidManifest.xml
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.blogtransaprentactivity"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="15" />
<application
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name=".VisibleActivity"
android:label="@string/title_activity_visible" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name=".TransparentActivity"
android:label="@string/title_activity_visible"
android:theme="@android:style/Theme.Translucent.NoTitleBar" />
</application>
</manifest>
layout_visible.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:padding="@dimen/padding_medium"
android:text="I'm below"/>
</RelativeLayout>
VisibleActivity.java
package com.example.blogtransaprentactivity;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.Menu;
public class VisibleActivity extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_visible);
startActivity(new Intent(this, TransparentActivity.class));
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.activity_visible, menu);
return true;
}
}
layout_transparent.xml
<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"
android:background="#80000000" >
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_marginTop="60dip"
android:padding="@dimen/padding_medium"
android:text="I'm above"
tools:context=".VisibleActivity" />
<Button
android:id="@+id/button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
android:text="Finish Activity" />
</RelativeLayout>
TransparentActivity.java
package com.example.blogtransaprentactivity;
import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
public class TransparentActivity extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_transparent);
((Button) findViewById(R.id.button))
.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
finish();
}
});
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.activity_visible, menu);
return true;
}
}
La imagen que podemos ver a continuación nos muestra la Activity transparente encima. Si pulsamos al botón de abajo desaparece y podemos ver la segunda imagen de forma nítida.
Roger Sala,
No hay comentarios:
Publicar un comentario