1

これは単純なはずですが、凡例の周囲から境界線を削除する方法がわかりません。また、凡例をグラフ内に配置し、内側のグリッド線と上下の境界線を削除したいと思います。私は散布図関数を使用しています。これは私がこれまでに書いたコードです。

scatterplot(Comp1~ln1wr|Season, moose,  
      xlab = "Risk", ylab = "Principal component 1",
      labels= row.names(moose), by.groups=T, smooth=F, boxplots=F, legend.plot=F)
      legend("bottomleft", moose, fill=0)

ここでは、凡例を別の場所に配置できるかどうかを確認するために実験を行っていましたが、このコードを実行するたびにエラーが発生します

Error in as.graphicsAnnot(legend) : 
  argument "legend" is missing, with no default

凡例をグラフ内に配置したいのですが、表示されているデータと競合しない場所に配置します。サンプルデータは次のとおりです。

structure(list(ID = structure(c(1L, 1L, 1L, 1L, 1L, 32L, 33L, 
33L, 34L, 34L, 34L), .Label = c("F07001", "F07002", "F07003", 
"F07004", "F07005", "F07006", "F07008", "F07009", "F07010", "F07011", 
"F07014", "F07015", "F07017", "F07018", "F07019", "F07020", "F07021", 
"F07022", "F07023", "F07024", "F10001", "F10004", "F10008", "F10009", 
"F10010", "F10012", "F10013", "F98015", "M07007", "M07012", "M07013", 
"M07016", "M10007", "M10011", "M10015"), class = "factor"), Season = structure(c(1L, 
1L, 1L, 2L, 2L, 2L, 1L, 1L, 1L, 1L, 2L), .Label = c("SUM", "WIN"
), class = "factor"), Time = structure(c(1L, 2L, 1L, 2L, 1L, 
2L, 1L, 2L, 1L, 2L, 1L), .Label = c("day", "night"), class = "factor"), 
    Repro = structure(c(2L, 2L, 2L, 2L, 2L, 3L, 3L, 3L, 3L, 3L, 
    3L), .Label = c("f", "fc", "m"), class = "factor"), Comp1 = c(-0.524557195, 
    -0.794214153, -0.408247216, -0.621285004, -0.238828585, 0.976634392, 
    -0.202405922, -0.633821539, -0.306163898, -0.302261589, 1.218779672
    ), ln1wr = c(0.833126490613386, 0.824526258616325, 0.990730077688989, 
    0.981816265754353, 0.933462450382474, 1.446048015519, 1.13253050687157, 
    1.1349442179155, 1.14965388471562, 1.14879830358128, 1.14055365645628
    )), .Names = c("ID", "Season", "Time", "Repro", "Comp1", 
"ln1wr"), row.names = c(1L, 2L, 3L, 4L, 5L, 220L, 221L, 222L, 
223L, 224L, 225L), class = "data.frame")
4

2 に答える 2

1

私は提案します

par(bty="l",las=1)
scatterplot(Comp1~ln1wr|Season, moose,  
      xlab = "Risk", ylab = "Principal component 1",
            labels= row.names(moose),
            by.groups=TRUE, smooth=FALSE, boxplots=FALSE,
            grid=FALSE,
            legend.plot=FALSE)
legend("bottomright", title="Season",
       legend=levels(moose$Season), bty="n",
       pch=1:2, col=1:2)
  • に示されているように、凡例ボックスを制御します- ?legend「なし」を意味します。bty"n"
  • 凡例を左下ではなく右下に配置しました。これは、データを回避する方がよいように思われるためです。
  • 以前bty="l"はボックスの上下の端を削除していました(これは「ボックスタイプL」を意味します)
  • 以前las=1はy軸の目盛りラベルを水平にしていました-あなたはそれを求めていませんでしたが、私はそれを強く好みます
  • grid=FALSE内部グリッド線を削除します
于 2012-11-29T14:56:33.733 に答える
0

各ムースには複数のポイントがあるため、ムースIDを一意にする必要があります。

legend( "bottomleft"、legend = unique(moose))

次に、色とポイントタイプを凡例に関連付ける必要があります(プロット内のムースIDに対応します)。また、scatterplot()の代わりにplot()も見てみます。

于 2012-11-28T17:01:02.843 に答える