How do I fix my legend?

1 回表示 (過去 30 日間)
Alex
Alex 2017 年 5 月 16 日
コメント済み: Walter Roberson 2017 年 5 月 16 日
Hello,
'parnam' contains 8 1x1 structures (data and text). The data contains the latitude, longitude and altitude of a sensor. I want to create a legend for my plot that states the latitude of each plot, but it only prints the first.
figure
for k=1:m
scatter(x(:,k),y(:,k)), hold on
legend(sprintf('aircraft at %2.2f degrees latitude', parnam{1,k}.data(1,1)))
end
hold off

採用された回答

dpb
dpb 2017 年 5 月 16 日
There's only one legend per plot; you're overwriting each pass thru the loop.
for k=1:m
scatter(x(:,k),y(:,k))
if k==1, hold on, end % can't get an "onner"
end
legend(num2str(parnam{1,1:m}.data(1,1)).','aircraft at %2.2f degrees latitude')
  3 件のコメント
Walter Roberson
Walter Roberson 2017 年 5 月 16 日
legend( cellstr( num2str( cellfun( @(C) C.data(1,1), parnam(1,1:m) ) .', 'aircraft at %2.2f degrees latitude' ) ) )
Walter Roberson
Walter Roberson 2017 年 5 月 16 日
Alex, your version will not work if some of the data values have a different number of digits, such as 3.7 degrees or 13.7 degrees. But you could use
figure
for k=1:m
scatter(x(:,k),y(:,k)), hold on
h{k} = sprintf('aircraft at %2.2f degrees latitude', parnam{1,k}.data(1,1)) ;
end
legend(h)
hold off

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeLegend についてさらに検索

タグ

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by