- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我陷入了一种情况,根据我的应用程序图表流程描述如下:
假设我在 Activity A 上,在单击按钮时,我从图库中选择图像,选择后,我将移动到 Activity B(它在内部来自 onActivity 结果 - 通过传递 Intent )。现在,当我在 Activity B 上并单击 Button 时,会调用 Custom Video maker。在这里,我拍摄了 10 秒的视频,然后我使用
完成了( Activity C)C.this.finish();
现在,根据 Android Activity 流程,我应该回到 Activity B,但在我的情况下,我得到一个黑屏几秒钟,然后获得 Activity A,而不是 Activity B。我不能透露我的代码,所以我没有附上它。对不起。如果有人可以帮助我提供这么多信息,请帮助我
代码:
点击按钮的 Activity B 代码 fragment :
btnTakeVideo.setOnClickListener(new OnClickListener() {
public void onClick(View arg0) {
Intent takePictureIntent = new Intent(TakeAnotherPhoto.this,Recorder.class);
startActivityForResult(takePictureIntent,CreateAuctionScreen.ACTION_TAKE_VIDEO);
}
});
这是onActivityResult
onActivityResult()
if(requestCode == CreateAuctionScreen.ACTION_TAKE_VIDEO) {
if (resultCode == RESULT_OK) {
if(CreateAuctionScreen.resetBitmap!=null)
{
CreateAuctionScreen.resetBitmap = null;
}
Drawable dd;
dd = getResources().getDrawable(R.drawable.list_pic_frame2x);
CreateAuctionScreen.bmpSize = ((BitmapDrawable)dd).getBitmap();
if(data != null){
Uri str = data.getData();
String path = getRealPathFromURI(str);
System.out.println(path);
Bitmap bmp = ThumbnailUtils.createVideoThumbnail(path, MediaStore.Images.Thumbnails.MINI_KIND);
CreateAuctionScreen.resetBitmap = Bitmap.createScaledBitmap(bmp, CreateAuctionScreen.bmpSize.getWidth(), CreateAuctionScreen.bmpSize.getHeight(), true);
if(CreateAuctionScreen.resetBitmap != null){
if(CreateAuctionScreen.thumbList.size() < 20){
dpv.set_chkString("Video");
dpv.get_chkString();
CreateAuctionScreen.chkList.add(dpv);
CreateAuctionScreen.str_thumbList.add(path);
CreateAuctionScreen.thumbList.add(CreateAuctionScreen.resetBitmap);
hl.setAdapter(new GallaryImageAdapter(TakeAnotherPhoto.this,CreateAuctionScreen.thumbList.size(),ImageAdapter.CREAT_AUCTION_SCREEN, CreateAuctionScreen.thumbList));
}else{
Toast.makeText(TakeAnotherPhoto.this, "You can add up to 20 pics & videos only", Toast.LENGTH_SHORT).show();
}
}
}
Activity C(客户录像机)
public class Recorder extends Activity implements SurfaceHolder.Callback{
Button myButton;
MediaRecorder mediaRecorder;
SurfaceHolder surfaceHolder;
boolean back;
Timer timer;
int counter = 1;
String strPath;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
back = false;
mediaRecorder = new MediaRecorder();
setContentView(R.layout.recorde);
initMediaRecorder();
timer = new Timer();
TimerTask timerTask = new TimerTask() {
@Override
public void run() {
if(counter<=10)
counter++;
//Android UI get Updated continouly
else {
// If condition full filled the timer will stop here
mediaRecorder.stop();
mediaRecorder.release();
timer.cancel();
Intent i = new Intent();
setResult(RESULT_OK, i.putExtra("returnedVideo", strPath));
Recorder.this.finish();
}
}
};
timer.schedule(timerTask, 1000, 1000);
SurfaceView myVideoView = (SurfaceView)findViewById(R.id.videoview);
surfaceHolder = myVideoView.getHolder();
surfaceHolder.addCallback(this);
surfaceHolder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
myButton = (Button)findViewById(R.id.mybutton);
myButton.setOnClickListener(myButtonOnClickListener);
}
private Button.OnClickListener myButtonOnClickListener
= new Button.OnClickListener(){
public void onClick(View arg0) {
// TODO Auto-generated method stub
mediaRecorder.stop();
mediaRecorder.release();
timer.cancel();
Intent i = new Intent();
setResult(RESULT_OK, i.putExtra("returnedVideo", strPath));
// i.putExtra("returnedVideo", strPath);
// i.putExtra("isRecorder", true);
// startActivity(i);
finish();
}};
public void surfaceChanged(SurfaceHolder arg0, int arg1, int arg2, int arg3) {
// TODO Auto-generated method stub
}
public void surfaceCreated(SurfaceHolder arg0) {
// TODO Auto-generated method stub
prepareMediaRecorder();
}
public void surfaceDestroyed(SurfaceHolder arg0) {
// TODO Auto-generated method stub
mediaRecorder.stop();
mediaRecorder.release();
//Recorder.this.finish();
}
@Override
public void onBackPressed() {
// TODO Auto-generated method stub
super.onBackPressed();
mediaRecorder.stop();
mediaRecorder.release();
}
private void initMediaRecorder(){
Random genraotr = new Random();
int n = 10000;
n = genraotr.nextInt(n);
mediaRecorder.setAudioSource(MediaRecorder.AudioSource.DEFAULT);
mediaRecorder.setVideoSource(MediaRecorder.VideoSource.DEFAULT);
CamcorderProfile camcorderProfile_HQ = CamcorderProfile.get(CamcorderProfile.QUALITY_HIGH);
mediaRecorder.setProfile(camcorderProfile_HQ);
mediaRecorder.setOutputFile("/sdcard/auction_video"+n+".mp4");
strPath = "/sdcard/auction_video"+n+".mp4";
mediaRecorder.setMaxDuration(10000); // Set max duration 10 sec.
mediaRecorder.setMaxFileSize(5000000); // Set max file size 5M
}
private void prepareMediaRecorder(){
mediaRecorder.setPreviewDisplay(surfaceHolder.getSurface());
try {
mediaRecorder.prepare();
mediaRecorder.start();
} catch (IllegalStateException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
谢谢
最佳答案
它似乎是 Activity B 中的异常。正如大家所建议的,调试 B 中的 OnActivityResult 函数。检查您是否正在检索函数中“System.out.println(path)”打印的正确路径。
关于Android onActivityResult,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13946669/
哪个更好,为什么? 这个: @Override public void onActivityResult(int requestCode, int resultCode, Intent intent)
在我的 fragment 中,我已经启动了用于照片捕获的 startActivityforresult Intent 。我已经覆盖了 fragment 类中的 onActivityResult 回调方
我已经实现了 Facebook 集成,并且在初始化部分工作正常,即使 Facebook APPID 也适用于应用程序。 让我更详细地解释一下:我已在 onCreate() 中添加并初始化 Facebo
我有代码可以让我从计算器中获取值并进一步使用它: //-----------------This section creates the keypad functionality for (int o
我陷入了一种情况,根据我的应用程序图表流程描述如下: 假设我在 Activity A 上,在单击按钮时,我从图库中选择图像,选择后,我将移动到 Activity B(它在内部来自 onActivity
我有一项 Activity 要求启用蓝牙和发现模式。 请求被正确执行并被 onactivityresult() 接收. 问题出在发现请求中。 如果我点击拒绝,那么 RESULT_CANCELED正确获
所以我尝试显示相机拍摄的图像,并希望稍后通过套接字发送它,但我注意到 onActivityResult() 方法没有被调用,现在导致了进一步的问题。我使用 RESULT_OK,但检查其值,使其不是负值
我的 MainActivity.java 中有一个类用作接口(interface): public class prova{ prova(){ } @JavascriptIn
我尝试通过启动 Intent 来使用 startActivityForResult 从照片库中进行选择并覆盖 onActivityResult 来获取图像。我不知道为什么,但是当我选择图像并尝试将其绘
每当我完成“ViewEvent” Activity 时,在“HomeFragment”中调用 onActivityResult() 时遇到问题。ViewEvents Activity 从适配器启动。
我有一个选择图像的 Intent (我在 fragment 中调用它): Intent intent = new Intent(Intent.ACTION_GET_CONTENT); int
我有一个 RecyclerView,其中的项目包含一个使用 startActivityForResult 启动 Activity 的按钮。 onClick 方法是在适配器内部实现的,并且在从新 Act
我有以下代码,它应该使用服务记录设备屏幕。 问题是,要使用它,我需要使用如下调用:startActivityForResult/onActivityResult,以获得能够录制屏幕的权限。 但是在 A
我有三项 Activity ,A、B 和 C(代码如下)。 A 使用 startActivityforResult 调用 B,并覆盖 onActivityResult,B 也使用 Activityfo
我有一个 Activity 1,它向 Activity 2 发送 Intent ,如下所示: Activity 1 periodDatetv.setOnClickListener(new OnClic
我正在尝试将其与我的应用程序集成:Capture Image from Camera and Display in Activity 当我打开 Activity 时,我完全使用了作者所写的内容,但出现
我有一个 MainActivity,它有两个 TextView。用户可以选择启动另一个 Activity 并从 ListView 中选择数据来填充这些 TextView。我的主要 Activity 有
这个问题在这里已经有了答案: How to manage startActivityForResult on Android (14 个回答) 3年前关闭。 请写下答案 如何在按钮单击时调用 frag
我怎么知道这个主题有很好的记录,我已经阅读了很多关于那个问题的文章,但我仍然遇到以下问题:当我用我的应用拍照并点击“验证”按钮时,没有任何反应。我正在做的事情的目的是:传递给 onActivityRe
从第一个 Activity 我想去第二个,然后从第二个到第三个。在第三个activity中,我想在EditText中输入姓名,然后按下按钮后,转到第一个activity,同时发送在第三项 Ac
我是一名优秀的程序员,十分优秀!