VB6.0用掲示板の過去のログ(No.1)−VBレスキュー(花ちゃん)
[記事リスト] [新規投稿] [新着記事] [ワード検索] [過去ログ] [管理用]

投稿日: 2003/04/05(Sat) 22:51
投稿者花ちゃん
Eメール
URL
タイトルRe^2: グリッドのBackColorについて

表示する数だけPictureBoxがいるのかな思ったのですが1個で出来るようなので
結構使えるかも知れません。
但し、その部分は強調表示されなかったり、セルのサイズ変更があれば再度塗りつぶし処理が
必要になったりと欠点もありますが、下記のようにして編集中は解除するようにして、セルの
サイズが変更されたら、再表示する等にすれば有る程度解決できるかと思います。
その他十分なテストやエラーチェックが出来ていませんので他に問題が発生するかも知れませんが
一度試して見て下さい。うまくいったら教えて下さい。

Option Explicit    

Private Sub Command1_Click()
'パターンによる塗りつぶしのテスト
    Dim i As Long, Pt As Long
    With MSFlexGrid1
        For i = .FixedCols To .Cols - 1
            '1行すべて表示
            Call SetPattern(5, 2, i)
            If Pt < 8 Then
                '全パターン表示
                Call SetPattern(Pt, 3, i)
            End If
            Pt = Pt + 1
        Next i
        '表示してからセルにデータを表示した場合のテスト
        .TextMatrix(2, 4) = "後で記入"
    End With
    'Row=4  Col=3 に VbCross 6 クロス で表示
    Call SetPattern(6, 4, 3)
End Sub

Private Sub Command2_Click()
'パターンを解除
    Dim i As Long, Pt As Long
    With MSFlexGrid1
        For i = .FixedCols To .Cols - 1
            Call SetPattern(8, 2, i)
            If Pt < 8 Then
                Call SetPattern(8, 3, i)
            End If
            Pt = Pt + 1
        Next i
    End With
    Call SetPattern(8, 4, 3)
End Sub

Private Sub SetPattern(ByVal FiSty As Integer, ByVal Ro As Long, ByVal Co As Long)
'パターンの作成と塗りつぶし処理
    With MSFlexGrid1
        .Row = Ro
        .Col = Co
        Picture1.Cls
        'ピクチャーのサイズをセルと同一に
        Picture1.Height = .CellHeight
        Picture1.Width = .CellWidth
        If FiSty >= 8 Or FiSty < 0 Then
            'パターンの解除(Picture をクリア)
            Set .CellPicture = LoadPicture()
            Exit Sub
        End If
        'パターンの設定
        Picture1.FillStyle = FiSty
        '枠の罫線が見えないように
        Picture1.Line (-10, -10)-(.CellWidth, .CellHeight), QBColor(0), B
        'セルにピクチャーを表示
        Set .CellPicture = Picture1.Image
    End With
End Sub

Private Sub Form_Load()
'MSFlexGridの初期設定
    With MSFlexGrid1
        .Cols = 10
        .Rows = 6
        .ColWidth(-1) = 900
        .ColWidth(5) = 1400
        .RowHeight(-1) = 350
        .Font.Bold = True
        .TextMatrix(2, 2) = "先に記入"
    End With
    With Picture1   '別途プロパティで設定して下さい
        .AutoRedraw = True
        .Appearance = 0
        .BorderStyle = vbBSNone
        .Visible = False
    End With
End Sub


- 関連一覧ツリー (★ をクリックするとツリー全体を一括表示します)

- 返信フォーム (この記事に返信する場合は下記フォームから投稿して下さい)

- Web Forum -