Skip to main content
.NET Framework Class Library
OpenFileDialog..::.ShowReadOnly Property

Gets or sets a value indicating whether the dialog box contains a read-only check box.

Namespace: System.Windows.Forms
Assembly: System.Windows.Forms (in System.Windows.Forms.dll)
Syntax
Public Property ShowReadOnly As Boolean
public bool ShowReadOnly { get; set; }
public:
property bool ShowReadOnly {
	bool get ();
	void set (bool value);
}
member ShowReadOnly : bool with get, set

Property Value

Type: System..::.Boolean
true if the dialog box contains a read-only check box; otherwise, false. The default value is false.
Examples

The following code example demonstrates the use of the ShowReadOnly property. This example displays the OpenFileDialog box with the ShowReadOnly property set to true. If the user clicks the option to open the file in read-only mode, the OpenFile method is used to open the file. Otherwise, the FileStream class is used to open the file in read/write mode.



    Private Function OpenFile() As FileStream

        ' Displays an OpenFileDialog and shows the read/only files.

        Dim DlgOpenFile As New OpenFileDialog()
        DlgOpenFile.ShowReadOnly = True

        If DlgOpenFile.ShowDialog() = System.Windows.Forms.DialogResult.OK Then
            Dim path As New String("")

            ' If ReadOnlyChecked is true, uses the OpenFile method to
            ' open the file with read/only access.
            Try
                If (DlgOpenFile.ReadOnlyChecked = True) Then
                    Return DlgOpenFile.OpenFile()
                Else
                    ' Otherwise, opens the file with read/write access.
                    Path = DlgOpenFile.FileName
                    Return New FileStream(Path, System.IO.FileMode.Open, _
                            System.IO.FileAccess.ReadWrite)
                End If
            Catch SecEx As SecurityException
                ' The user lacks appropriate permissions to read files, discover paths, etc.
                MessageBox.Show("Security error. Please contact your administrator for details.\n\n" & _
                    "Error message: " & SecEx.Message * "\n\n" & _
                    "Details (send to Support):\n\n" & SecEx.StackTrace)
            Catch Ex As Exception
                ' Could not load the image - probably related to Windows file system permissions.
                MessageBox.Show("Cannot display the image: " & path.Substring(path.LastIndexOf("\\")) & _
                         ". You may not have permission to read the file, or " & _
                        "it may be corrupt.\n\nReported error: " + ex.Message)
            End Try
        End If

        Return Nothing
    End Function



    private FileStream OpenFile()
    {
        // Displays an OpenFileDialog and shows the read/only files.

        OpenFileDialog dlgOpenFile = new OpenFileDialog();
        dlgOpenFile.ShowReadOnly = true;


        if(dlgOpenFile.ShowDialog() == DialogResult.OK)
        {

            // If ReadOnlyChecked is true, uses the OpenFile method to
            // open the file with read/only access.
            string path = null;

            try {
                if(dlgOpenFile.ReadOnlyChecked == true)
                {
                    return (FileStream)dlgOpenFile.OpenFile();
                }

                // Otherwise, opens the file with read/write access.
                else
                {
                    path = dlgOpenFile.FileName;
                    return new FileStream(path, System.IO.FileMode.Open,
                                System.IO.FileAccess.ReadWrite);
                }
            } catch (SecurityException ex)
                {
                    // The user lacks appropriate permissions to read files, discover paths, etc.
                    MessageBox.Show("Security error. Please contact your administrator for details.\n\n" +
                        "Error message: " + ex.Message + "\n\n" +
                        "Details (send to Support):\n\n" + ex.StackTrace
                    );
                }
                catch (Exception ex)
                {
                    // Could not load the image - probably related to Windows file system permissions.
                    MessageBox.Show("Cannot display the image: " + path.Substring(path.LastIndexOf('\\'))
                        + ". You may not have permission to read the file, or " +
                        "it may be corrupt.\n\nReported error: " + ex.Message);
                }
        }

        return null;
    }



private:
   FileStream^ OpenFile()
   {
      // Displays an OpenFileDialog and shows the read/only files.
      OpenFileDialog^ dlgOpenFile = gcnew OpenFileDialog;
      dlgOpenFile->ShowReadOnly = true;
      if ( dlgOpenFile->ShowDialog() == ::DialogResult::OK )
      {
         // If ReadOnlyChecked is true, uses the OpenFile method to
         // open the file with read/only access.
         if ( dlgOpenFile->ReadOnlyChecked == true )
         {
            return dynamic_cast<FileStream^>(dlgOpenFile->OpenFile());
         }
         // Otherwise, opens the file with read/write access.
         else
         {
            String^ path = dlgOpenFile->FileName;
            return gcnew FileStream( path,System::IO::FileMode::Open,System::IO::FileAccess::ReadWrite );
         }
      }

      return nullptr;
   }

Version Information

.NET Framework

Supported in: 4, 3.5, 3.0, 2.0, 1.1, 1.0

.NET Framework Client Profile

Supported in: 4, 3.5 SP1
Platforms

Windows 7, Windows Vista SP1 or later, Windows XP SP3, Windows XP SP2 x64 Edition, Windows Server 2008 (Server Core not supported), Windows Server 2008 R2 (Server Core supported with SP1 or later), Windows Server 2003 SP2

The .NET Framework does not support all versions of every platform. For a list of the supported versions, see .NET Framework System Requirements.