草庐IT

android - 从 Activity 上下文外部调用 startActivity() 需要 FLAG_ACTIVITY_NEW_TASK 标志异常 - Android

coder 2023-11-28 原文

我创建了一个相机 Activity ,它将从后置和前置相机拍摄照片。但我不断收到上述错误,任何人都可以帮助我:

似乎我在调用 Intent 时在 Menifest 文件中犯了一些错误,但无法弄清楚我在做什么错误。

这是我的 CameraActivity.java

    public class CameraActivity extends Activity {

        private static CameraActivity inst;

        private Camera mCamera;
        private CameraPreview mPreview;
        private MediaRecorder mMediaRecorder;
        private FrameLayout preview;
        private boolean isRecording = false;

        private static final int CAPTURE_IMAGE_ACTIVITY_REQUEST_CODE = 100;
        private static final int CAPTURE_VIDEO_ACTIVITY_REQUEST_CODE = 200;
        public static final int MEDIA_TYPE_IMAGE = 1;
        public static final int MEDIA_TYPE_VIDEO = 2;
        private static boolean isPictureTaken = false;
        private static int cameraCount = 0;

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

            Log.d("TestCase", "in camera activity on create");

            inst = this;

            Intent localIntent = getIntent();
            //Intent localIntent = new Intent("com.test.TestCase.core.util.CameraActivity");
            //localIntent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK); 
            String cameraMode = localIntent.getExtras().getString("Camera");
            Log.d("TestCase", "CameraMode" + cameraMode);
            if (cameraMode.equals("FrontCamera"))
                inst.mCamera = openFrontFacingCamera();
            else
                inst.mCamera = openRearFacingCamera();

            setCameraView();

        }

        private void setCameraView() {

            if (inst.mCamera != null) {
                Log.d("TestCase", "Got the Camera Instance");
            } else {
                Log.d("TestCase", "Camera Instance obtained is null");
            }

            // Create our Preview view and set it as the content of our activity.
            inst.mPreview = new CameraPreview(this, mCamera);
            inst.preview = (FrameLayout) findViewById(R.id.camera_preview);
            inst.preview.addView(mPreview);

        }

        private Camera openRearFacingCamera() {
            Camera cam = null;
            Camera.CameraInfo cameraInfo = new Camera.CameraInfo();
            cameraCount = Camera.getNumberOfCameras();
            Log.d("Camera", "Camera COunt : " + cameraCount);

            for (int camIdx = 0; camIdx < cameraCount; camIdx++) {

                Log.d("Camera", " CamIdx : " + camIdx);

                Camera.getCameraInfo(camIdx, cameraInfo);

                if (cameraInfo.facing == Camera.CameraInfo.CAMERA_FACING_BACK) {
                    try {
                        cam = Camera.open(camIdx);
                        break;
                    } catch (RuntimeException e) {
                        for (StackTraceElement st : e.getStackTrace())
                            Log.d("Camera", st.toString());
                        // Log.e("Camera failed to open: " +
                        // e.getLocalizedMessage());
                    }
                }
            }

            return cam;
        }

        @Override
        protected void onActivityResult(int requestCode, int resultCode, Intent data) {
            if (requestCode == CAPTURE_IMAGE_ACTIVITY_REQUEST_CODE) {
                if (resultCode == RESULT_OK) {
                    // Image captured and saved to fileUri specified in the Intent
                    Toast.makeText(this, "Image saved to:\n" + data.getData(),
                            Toast.LENGTH_LONG).show();
                } else if (resultCode == RESULT_CANCELED) {
                    // User cancelled the image capture
                } else {
                    // Image capture failed, advise user
                }
            }

            if (requestCode == CAPTURE_VIDEO_ACTIVITY_REQUEST_CODE) {
                if (resultCode == RESULT_OK) {
                    // Video captured and saved to fileUri specified in the Intent
                    Toast.makeText(this, "Video saved to:\n" + data.getData(),
                            Toast.LENGTH_LONG).show();
                } else if (resultCode == RESULT_CANCELED) {
                    // User cancelled the video capture
                } else {
                    // Video capture failed, advise user
                }
            }
        }

        /** A safe way to get an instance of the Camera object. */
        private Camera openFrontFacingCamera() {
            // int cameraCount = 0;
            Camera cam = null;
            Camera.CameraInfo cameraInfo = new Camera.CameraInfo();
            cameraCount = Camera.getNumberOfCameras();
            Log.d("Camera", "Camera COunt : " + cameraCount);

            for (int camIdx = 0; camIdx < cameraCount; camIdx++) {

                Log.d("Camera", " CamIdx : " + camIdx);

                Camera.getCameraInfo(camIdx, cameraInfo);

                if (cameraInfo.facing == Camera.CameraInfo.CAMERA_FACING_FRONT) {
                    try {
                        cam = Camera.open(camIdx);
                        break;
                    } catch (RuntimeException e) {
                        for (StackTraceElement st : e.getStackTrace())
                            Log.d("Camera", st.toString());
                        // Log.e("Camera failed to open: " +
                        // e.getLocalizedMessage());
                    }
                }
            }

            return cam;
        }

        @Override
        public void onStart() {
            try {
                super.onStart();

            } catch (Exception localException) {
                Log.d("TestCase", localException.getMessage());
            }
        }

        @Override
        public boolean onCreateOptionsMenu(Menu menu) {
            // Inflate the menu; this adds items to the action bar if it is present.
            getMenuInflater().inflate(R.menu.camera, menu);
            return true;
        }

        @Override
        public boolean onOptionsItemSelected(MenuItem item) {
            // Handle action bar item clicks here. The action bar will
            // automatically handle clicks on the Home/Up button, so long
            // as you specify a parent activity in AndroidManifest.xml.
            int id = item.getItemId();
            if (id == R.id.action_settings) {
                return true;
            }
            return super.onOptionsItemSelected(item);
        }

        private PictureCallback mPicture = new PictureCallback() {

            @Override
            public void onPictureTaken(byte[] data, Camera camera) {

                File pictureFile = getOutputMediaFile(MEDIA_TYPE_IMAGE);
                if (pictureFile == null) {
                    Log.d("TestCase",
                            "Error creating media file, check storage permissions: ");
                    return;
                }

                try {
                    Log.d("TestCase", "Picture taken");
                    FileOutputStream fos = new FileOutputStream(pictureFile);
                    fos.write(data);
                    fos.close();

                    Log.d("TestCase", "Picture saved");
                    CameraActivity.isPictureTaken = true;

                } catch (FileNotFoundException e) {
                    Log.d("TestCase", "File not found: " + e.getMessage());
                } catch (IOException e) {
                    Log.d("TestCase", "Error accessing file: " + e.getMessage());
                }

                try {
                    inst.mCamera.stopPreview();

                } catch (Exception e) {
                    // ignore: tried to stop a non-existent preview
                }

                // inst.mCamera.release();

                // set preview size and make any resize, rotate or
                // reformatting changes here

                // start preview with new settings
                try {
                    inst.mCamera.setPreviewDisplay(mPreview.getHolder());
                    inst.mCamera.startPreview();

                } catch (Exception e) {
                    Log.d("TestCase",
                            "Error starting camera preview: " + e.getMessage());
                }
            }
        };

        public void onCameraClick(View view) {
            try {

                takePicture();

            } catch (Exception localException) {
                Log.d("TestCase", localException.getMessage());
            }
        }

        private void takePicture() {

            inst.mCamera.takePicture(null, null, mPicture);
        }

        /** Create a File for saving an image or video */
        private static File getOutputMediaFile(int type) {
            // To be safe, you should check that the SDCard is mounted
            // using Environment.getExternalStorageState() before doing this.

            File mediaStorageDir = new File(
                    Environment
                            .getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES),
                    "TestCase_CamMedia");
            // This location works best if you want the created images to be shared
            // between applications and persist after your app has been uninstalled.

            // Create the storage directory if it does not exist
            if (!mediaStorageDir.exists()) {
                if (!mediaStorageDir.mkdirs()) {
                    Log.d("TestCase", "failed to create directory");
                    return null;
                }
            }

            // Create a media file name
            String timeStamp = new SimpleDateFormat("yyyyMMdd_HHmmss",
                    Locale.getDefault()).format(new Date());
            File mediaFile;
            if (type == MEDIA_TYPE_IMAGE) {
                mediaFile = new File(mediaStorageDir.getPath() + File.separator
                        + "IMG_" + timeStamp + ".jpg");
            } else if (type == MEDIA_TYPE_VIDEO) {
                mediaFile = new File(mediaStorageDir.getPath() + File.separator
                        + "VID_" + timeStamp + ".mp4");
            } else {
                return null;
            }

            return mediaFile;
        }

        private boolean prepareVideoRecorder() {

            // mCamera = getCameraInstance();
            inst.mMediaRecorder = new MediaRecorder();
            // Step 1: Unlock and set camera to MediaRecorder
            inst.mCamera.unlock();

            inst.mMediaRecorder.setCamera(mCamera);

            // Step 2: Set sources
            inst.mMediaRecorder.setAudioSource(MediaRecorder.AudioSource.CAMCORDER);
            inst.mMediaRecorder.setVideoSource(MediaRecorder.VideoSource.CAMERA);

            // Step 3: Set a CamcorderProfile (requires API Level 8 or higher)
            inst.mMediaRecorder.setProfile(CamcorderProfile
                    .get(CamcorderProfile.QUALITY_HIGH));

            // Step 4: Set output file
            inst.mMediaRecorder.setOutputFile(getOutputMediaFile(MEDIA_TYPE_VIDEO)
                    .toString());

            // Step 5: Set the preview output
            inst.mMediaRecorder
                    .setPreviewDisplay(mPreview.getHolder().getSurface());

            // Step 6: Prepare configured MediaRecorder
            try {

                mMediaRecorder.prepare();
            } catch (IllegalStateException e) {
                Log.d("TestCase",
                        "IllegalStateException preparing MediaRecorder: "
                                + e.getMessage());
                inst.releaseMediaRecorder();
                return false;
            } catch (IOException e) {
                Log.d("TestCase",
                        "IOException preparing MediaRecorder: " + e.getMessage());
                inst.releaseMediaRecorder();
                return false;
            }
            return true;

        }

        @Override
        protected void onPause() {
            super.onPause();
            inst.releaseMediaRecorder(); // if you are using MediaRecorder, release
                                            // it first
            inst.releaseCamera(); // release the camera immediately on pause event
        }

        private void releaseMediaRecorder() {
            if (inst.mMediaRecorder != null) {
                inst.mMediaRecorder.reset(); // clear recorder configuration
                inst.mMediaRecorder.release(); // release the recorder object
                inst.mMediaRecorder = null;
                inst.mCamera.lock(); // lock camera for later use
            }
        }

        private void releaseCamera() {
            if (inst.mCamera != null) {
                inst.mCamera.release(); // release the camera for other applications
                inst.mCamera = null;
            }
        }

        public void recordVideo() {
            if (!inst.isRecording) {
                if (inst.prepareVideoRecorder()) {
                    // Camera is available and unlocked, MediaRecorder is prepared,
                    // now you can start recording
                    inst.mMediaRecorder.start();
                    Log.d("TestCase", "started video recording");
                    // inform the user that recording has started

                    inst.isRecording = true;
                } else
                    inst.releaseMediaRecorder();
            }
        }

        public void stopRecording() {
            if (inst.isRecording) {
                // stop recording and release camera
                inst.mMediaRecorder.stop(); // stop the recording
                Log.d("TestCase", "stopped video recording");
                inst.releaseMediaRecorder(); // release the MediaRecorder object
                inst.mCamera.lock(); // take camera access back from MediaRecorder

                // inform the user that recording has stopped
                inst.isRecording = false;
            }
        }

        public void onRecordVideo(View view) {
            try {
                inst.recordVideo();
            } catch (Exception localException) {
                Log.d("TestCase", localException.getMessage());
            }
        }

        public void onStopRecording(View view) {
            try {
                inst.stopRecording();
            } catch (Exception localException) {
                Log.d("TestCase", localException.getMessage());
            }
        }

        public static boolean TakePicture() {
            inst.takePicture();
            return CameraActivity.isPictureTaken;
        }

        public static boolean RecordVideo() {
            inst.recordVideo();
            return inst.isRecording;
        }

        public static boolean StopVideo() {
            inst.stopRecording();
            return !inst.isRecording;
        }

        public static void CloseCamera() {
            inst.finish();
        }

        public static boolean ToggleCamera() throws Exception {

            for(int i=1; i<=3 ; i++) {
                if(i%2==0)
                    inst.mCamera = inst.openRearFacingCamera();
                else
                    inst.mCamera = inst.openFrontFacingCamera();

                if (inst.mCamera != null) {
                    Log.d("TestCase", "Got the Camera Instance");
                } else {
                    Log.d("TestCase", "Camera Instance obtained is null");
                }
                inst.setCameraView();
                Thread.sleep(10000L);
            }
            return true;

        }
    }



**Here is ManifestFile :**

    <?xml version="1.0" encoding="utf-8"?>
    <manifest xmlns:android="http://schemas.android.com/apk/res/android"
        package="com.TestCase.TestCase"
        android:versionCode="1"
        android:versionName="1.0" >

        <uses-sdk
            android:maxSdkVersion="21"
            android:minSdkVersion="14"
            android:targetSdkVersion="21" />

        <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
        <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
        <uses-permission android:name="android.permission.INTERACT_ACROSS_USERS_FULL" />
        <uses-permission android:name="android.permission.INTERNET" />
        <uses-permission android:name="android.permission.NFC" />
        <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" /
        <uses-feature android:name="android.hardware.camera" />
        <uses-feature android:name="android.hardware.camera.flash" />

        <uses-permission android:name="android.permission.RECORD_AUDIO" />

        <application
            android:allowBackup="true"
            android:icon="@drawable/ic_launcher"
            android:label="@string/app_name"
            android:theme="@style/AppTheme" >
            <activity
                android:name=".main_activities.TestCaseActivity"
                android:label="@style/AppTheme" >
                <intent-filter>
                    <action android:name="android.intent.action.MAIN" />

                    <category android:name="android.intent.category.LAUNCHER" />
                </intent-filter>
            </activity>
            <activity
                android:name="com.TestCase.TestCase.core.util.CameraActivity"
                android:label="@string/title_activity_camera" >
            </activity>

            <activity android:name=".main_activities.SetPreferenceActivity" />
            <activity
                android:name=".main_activities.SummaryActivity"
                android:label="@string/title_activity_summary" >
            </activity>

            <activity
                android:name="com.TestCase.TestCase.main_activities.AboutActivity"
                android:label="@string/title_activity_about" >
            </activity>

            <service android:name=".services.MasterService" />
            <service android:name=".services.TestCaseBootService" />
            <service android:name=".services.ActivityLauncherService" />

            <receiver android:name=".recievers.BootReciever" >
                <intent-filter>
                    <action android:name="android.intent.action.BOOT_COMPLETED" />
                </intent-filter>
            </receiver>
            <receiver android:name="com.TestCase.TestCase.framework.TestActionEndBroadcastReceiver" >
            </receiver>
            <receiver android:name="com.TestCase.TestCase.system.TestProgressUpdater$UpdateBroadcast" >
            </receiver>
        </application>

    </manifest>

Logcat : 

 11-03 19:31:21.782: D/TestCase(11635): [11.03.14_19:31:021]    came back from thread starting itest action 
    11-03 19:31:21.782: D/TestCase(11635): [11.03.14_19:31:021] Came back after starting action thread
    11-03 19:31:21.804: D/TestCase(11635): [11.03.14_19:31:021] from thread starting itest action 
    11-03 19:31:21.806: D/TestCase(11635): [11.03.14_19:31:021] Recieved onFinishPrepare
    11-03 19:31:21.834: D/TestCase(11635): [11.03.14_19:31:021] Error found when test is running: android.util.AndroidRuntimeException: Calling startActivity() from outside of an Activity  context requires the FLAG_ACTIVITY_NEW_TASK flag. Is this really what you want?
    11-03 19:31:21.834: D/TestCase(11635):  at android.app.ContextImpl.startActivity(ContextImpl.java:1232)
    11-03 19:31:21.834: D/TestCase(11635):  at android.app.ContextImpl.startActivity(ContextImpl.java:1219)
    11-03 19:31:21.834: D/TestCase(11635):  at android.content.ContextWrapper.startActivity(ContextWrapper.java:322)
    11-03 19:31:21.834: D/TestCase(11635):  at com.originatorTestCase.TestCase.core.multimedia.LaunchRearCameraTestAction.start(LaunchRearCameraTestAction.java:24)
    11-03 19:31:21.834: D/TestCase(11635):  at com.originatorTestCase.TestCase.framework.TestActionExecutor.startAction(TestActionExecutor.java:54)
    11-03 19:31:21.834: D/TestCase(11635):  at com.originatorTestCase.TestCase.framework.TestActionExecutor.access$1(TestActionExecutor.java:49)
    11-03 19:31:21.834: D/TestCase(11635):  at com.originatorTestCase.TestCase.framework.TestActionExecutor$ActionThread.run(TestActionExecutor.java:166)
    11-03 19:31:21.837: D/TestCase(11635): [11.03.14_19:31:021] TestAction Execution Finished : LaunchRearCamera id : 3
    11-03 19:31:21.838: D/TestCase(11635): [11.03.14_19:31:021] TestRunner onFinish(ITestAction) : [null]nullnull(null):
    11-03 19:31:21.862: D/TestCase(11635): [11.03.14_19:31:021] Completed [LaunchRearCamera TestAction] iteration : 1
    11-03 19:31:21.862: D/TestCase(11635): RESULT = [action="LaunchRearCamera" status="FAIL" iteration="1" startTime="11.03.14 19:31:21" duration="0" endTime="11.03.14 19:31:21" failedReason=" [null]nullnull(null): Executing error : android.util.AndroidRuntimeException: Calling startActivity() from outside of an Activity  context requires the FLAG_ACTIVITY_NEW_TASK flag. Is this really what you want? ""]
    11-03 19:31:21.863: D/TestCase(11635): [11.03.14_19:31:021] Has errors so stop test case RearCameraTakePictureTest
    11-03 19:31:21.886: D/TestCase(11635): [11.03.14_19:31:021] Completed total 1 iterations for action LaunchRearCamera.
    11-03 19:31:21.888: D/TestCase(11635): [11.03.14_19:31:021] ==========================================================
    11-03 19:31:21.906: D/TestCase(11635): [11.03.14_19:31:021] ==========================================================
    11-03 19:31:21.912: D/TestCase(11635): [11.03.14_19:31:021] Start Test Action TakePicture
    11-03 19:31:21.922: D/TestCase(11635): [11.03.14_19:31:021] Preparing for test action TakePicture
    11-03 19:31:21.925: D/TestCase(11635): [11.03.14_19:31:021] Begin [TakePicture TestAction] iteration : 1
    11-03 19:31:21.928: D/TestCase(11635): [11.03.14_19:31:021] Next random TakePicture-duration = 15
    11-03 19:31:21.947: D/TestCase(11635): [11.03.14_19:31:021] triggering schedule Task
    11-03 19:31:21.966: D/TestCase(11635): [11.03.14_19:31:021] initializing task infor
    11-03 19:31:21.968: D/TestCase(11635): [11.03.14_19:31:021] initializing thread
    11-03 19:31:21.974: D/TestCase(11635): [11.03.14_19:31:021] adding thread to task info
    11-03 19:31:21.976: D/TestCase(11635): [11.03.14_19:31:021] putting thread refrence in concurrent hash map
    11-03 19:31:21.977: D/TestCase(11635): [11.03.14_19:31:021] starting thread
    11-03 19:31:21.979: D/TestCase(11635): [11.03.14_19:31:021] came back after starting thread
    11-03 19:31:21.991: D/TestCase(11635): [11.03.14_19:31:021] in Action thread. 
    11-03 19:31:21.991: D/TestCase(11635): [11.03.14_19:31:021] Acquire WL for TakePicture
    11-03 19:31:21.995: D/TestCase(11635): [11.03.14_19:31:021] came back after triggering schedule Task
    11-03 19:31:21.996: D/TestCase(11635): [11.03.14_19:31:021] Came back after call back of testAction : LaunchRearCamera
    11-03 19:31:21.996: D/TestCase(11635): [11.03.14_19:31:021] Came back after starting action thread
    11-03 19:31:22.014: D/TestCase(11635): [11.03.14_19:31:022] from thread starting itest action 
    11-03 19:31:22.015: D/TestCase(11635): [11.03.14_19:31:022] Recieved onFinishPrepare
    11-03 19:31:22.024: D/TestCase(11635): [11.03.14_19:31:022] Error found when test is running: java.lang.NullPointerException: Attempt to invoke direct method 'void com..core.util.CameraActivity.takePicture()' on a null object reference
    11-03 19:31:22.024: D/TestCase(11635):  at core.util.CameraActivity.TakePicture(CameraActivity.java:403)
    11-03 19:31:22.024: D/TestCase(11635):  at 

最佳答案

你的问题在这里:

在 com.qualcomm.post.core.multimedia.LaunchRearCameraTestAction.start(LaunchRearCameraTestAction.java:24)

在这段代码中,您需要在调用 startActivity() 之前将新任务标志添加到 Intent 中:

intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);

关于android - 从 Activity 上下文外部调用 startActivity() 需要 FLAG_ACTIVITY_NEW_TASK 标志异常 - Android,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26718250/

有关android - 从 Activity 上下文外部调用 startActivity() 需要 FLAG_ACTIVITY_NEW_TASK 标志异常 - Android的更多相关文章

  1. ruby - 我需要将 Bundler 本身添加到 Gemfile 中吗? - 2

    当我使用Bundler时,是否需要在我的Gemfile中将其列为依赖项?毕竟,我的代码中有些地方需要它。例如,当我进行Bundler设置时:require"bundler/setup" 最佳答案 没有。您可以尝试,但首先您必须用鞋带将自己抬离地面。 关于ruby-我需要将Bundler本身添加到Gemfile中吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4758609/

  2. ruby - rspec 需要 .rspec 文件中的 spec_helper - 2

    我注意到像bundler这样的项目在每个specfile中执行requirespec_helper我还注意到rspec使用选项--require,它允许您在引导rspec时要求一个文件。您还可以将其添加到.rspec文件中,因此只要您运行不带参数的rspec就会添加它。使用上述方法有什么缺点可以解释为什么像bundler这样的项目选择在每个规范文件中都需要spec_helper吗? 最佳答案 我不在Bundler上工作,所以我不能直接谈论他们的做法。并非所有项目都checkin.rspec文件。原因是这个文件,通常按照当前的惯例,只

  3. ruby - 如何在 Lion 上安装 Xcode 4.6,需要用 RVM 升级 ruby - 2

    我实际上是在尝试使用RVM在我的OSX10.7.5上更新ruby,并在输入以下命令后:rvminstallruby我得到了以下回复:Searchingforbinaryrubies,thismighttakesometime.Checkingrequirementsforosx.Installingrequirementsforosx.Updatingsystem.......Errorrunning'requirements_osx_brew_update_systemruby-2.0.0-p247',pleaseread/Users/username/.rvm/log/138121

  4. ruby - 为什么在 ruby​​ 中创建 Rational 不需要新方法 - 2

    这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Rubysyntaxquestion:Rational(a,b)andRational.new!(a,b)我正在阅读ruby镐书,我对创建有理数的语法感到困惑。Rational(3,4)*Rational(1,2)产生=>3/8为什么Rational不需要new方法(我还注意到例如我可以在没有new方法的情况下创建字符串)?

  5. 安卓apk修改(Android反编译apk) - 2

    最近因为项目需要,需要将Android手机系统自带的某个系统软件反编译并更改里面某个资源,并重新打包,签名生成新的自定义的apk,下面我来介绍一下我的实现过程。APK修改,分为以下几步:反编译解包,修改,重打包,修改签名等步骤。安卓apk修改准备工作1.系统配置好JavaJDK环境变量2.需要root权限的手机(针对系统自带apk,其他软件免root)3.Auto-Sign签名工具4.apktool工具安卓apk修改开始反编译本文拿Android系统里面的Settings.apk做demo,具体如何将apk获取出来在此就不过多介绍了,直接进入主题:按键win+R输入cmd,打开命令窗口,并将路

  6. ruby-on-rails - 需要帮助最大化多个相似对象中的 3 个因素并适当排序 - 2

    我需要用任何语言编写一个算法,根据3个因素对数组进行排序。我以度假村为例(如Hipmunk)。假设我想去度假。我想要最便宜的地方、最好的评论和最多的景点。但是,显然我找不到在所有3个中都排名第一的方法。Example(assumingthereare20importantattractions):ResortA:$150/night...98/100infavorablereviews...18of20attractionsResortB:$99/night...85/100infavorablereviews...12of20attractionsResortC:$120/night

  7. ruby - 我需要从 facebook 游戏中抓取数据——使用 ruby - 2

    修改(澄清问题)我已经花了几天时间试图弄清楚如何从Facebook游戏中抓取特定信息;但是,我遇到了一堵又一堵砖墙。据我所知,主要问题如下。我可以使用Chrome的检查元素工具手动查找我需要的html-它似乎位于iframe中。但是,当我尝试抓取该iframe时,它​​是空的(属性除外):如果我使用浏览器的“查看页面源代码”工具,这与我看到的输出相同。我不明白为什么我看不到iframe中的数据。答案不是它是由AJAX之后添加的。(我知道这既是因为“查看页面源代码”可以读取Ajax添加的数据,也是因为我有b/c我一直等到我可以看到数据页面之后才抓取它,但它仍然不存在)。发生这种情况是因为

  8. ruby - 需要重构为新的 Ruby 1.9 哈希语法 - 2

    这个问题在这里已经有了答案:HashsyntaxinRuby[duplicate](1个回答)关闭5年前。我有一个Recipe,其中包含以下未通过lint测试的代码:service'apache'dosupports:status=>true,:restart=>true,:reload=>trueend失败并出现错误:UsethenewRuby1.9hashsyntax.supports:status=>true,:restart=>true,:reload=>true不确定新语法是什么样的...有人可以帮忙吗?

  9. ruby-on-rails - 我真的需要在 Rails 中使用 csv gem 吗? - 2

    我的问题很简单:我是否必须在使用RubyonRails的类上require'csv'?如果我打开一个railsconsole并尝试使用CSVgem它可以工作,但我必须在文件中这样做吗? 最佳答案 CSVlibrary是ruby​​标准库的一部分;它不是gem(即第三方库)。与所有标准库(与核心库不同)一样,csv不会由ruby​​解释器自动加载。所以是的,在您的应用程序中某处您确实需要要求它:irb(main):001:0>CSVNameError:uninitializedconstantCSVfrom(irb):1from/Us

  10. ruby-on-rails - 我需要一个真正的 UNIX RoR 开发环境 - 2

    从一开始,我就是一个Windows高手。我从MS-DOS开始。我安装了Windows2.1以及此后的所有Windows。现在,我家里有10台不同的Windows机器在运行,从Windows7Ultimate到各种版本的WindowsServer。我还没有完成Windows8,也不想去那里。我在服务器和各种软件方面都有UNIX经验,但它并不是我的首选环境。但是,我想我正在转换。我试图假装使用Cygwin和MSYS在Windows下运行UNIX。我的目的是搭建一个开发环境。两者都让我失望了。我花了比开发更多的时间来解决一系列技术问题。这是NotAcceptable。到目前为止,我的Ruby

随机推荐